【LeetCode】力扣题——轮转数组、消失的数字、数组串联

🔥个人主页:艾莉丝努力练剑

❄专栏传送门:《C语言》、《数据结构与算法》、C语言刷题12天IO强训

🍉学习方向:C/C++方向

⭐️人生格言:为天地立心,为生民立命,为往圣继绝学,为万世开太平



前言:牛客网和LeetCode的刷题都不可或缺,我们都做一做,力扣的题目对提升代码能力很有帮助,需要有一点基础,几乎都是接口型的题目,在C语言刷题专栏我好像还没有介绍过这两者的区别,那么我们来了解一下——IO型和接口型都是在线OJ的编程形式,区别在于:IO型:输入输出格式处理,又被称为输入输出型;

接口型:特定功能模块的逻辑实现,又被称为函数实现型。

解释一下,IO型就是输入输出要程序员自己写,接口型则不需要。 


目录

正文

一、用数组逆置方法求解轮转数组

二、malloc实现数组串联

三、异或方法求解消失的数字

结尾


正文

每一道题,博主都在力扣网站写了题解,博主会把网址放到每个版块开头。

一、用数组逆置方法求解轮转数组

189. 轮转数组 - 力扣(LeetCode)

这道题是我们的老熟人了,我在介绍数据结构与算法中的算法复杂度一文中就分三种思路介绍过轮转数组这道题了,所以在本文中博主就不赘述了,直接上链接!

【数据结构】详解算法复杂度:时间复杂度和空间复杂度

思路

你选用何种方法解题?数组逆置

解题过程

这些方法具体怎么运用?先逆置后k次,再逆置前nums-k次,最后再整体逆置

复杂度

  • 时间复杂度:O(n) 
  • 空间复杂度:O(1)

代码演示——

// void my_reverse(int*nums,int left,int right)
// {
//     while(left < right)
//     {
//         int tmp = nums[left];
//         nums[left] = nums[right];
//         nums[right] = tmp;//         left++;
//         right--;
//     }
// }// void rotate(int*nums,int numsSize,int k)
// {
//     k = k % numsSize;
//     my_reverse(nums,0,numsSize-k-1);
//     my_reverse(nums,numsSize-k,numsSize-1);
//     my_reverse(nums,0,numsSize-1);
// }void my_reverse(int*nums,int left,int right)
{while(left < right){int tmp = nums[left];nums[left] = nums[right];nums[right] = tmp;left++;right--;}
}void rotate(int*nums,int numsSize,int k)
{if(k >= numsSize){k = k % numsSize;}my_reverse(nums,0,numsSize-k-1);my_reverse(nums,numsSize-k,numsSize-1);my_reverse(nums,0,numsSize-1);
}

二、malloc实现数组串联

1929. 数组串联 - 力扣(LeetCode)

思路

你选用何种方法解题?malloc开辟空间,for循环遍历数组

解题过程

这些方法具体怎么运用?malloc开辟大小为numsSize*sizeof(int)*2的空间,再强制类型转换,for循环遍历数组,用题目所给的串联数组关系,就可以了

复杂度

  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

代码演示——

/*** Note: The returned array must be malloced, assume caller calls free().*/
int* getConcatenation(int* nums, int numsSize, int* returnSize) 
{int *ans = (int *)malloc(numsSize*sizeof(int)*2);for(int i = 0;i < numsSize;i++){ans[i] = nums[i];ans[i + numsSize] = nums[i];}*returnSize = numsSize * 2;return ans;
}​

三、异或方法求解消失的数字

面试题 17.04. 消失的数字 - 力扣(LeetCode)

思路

你选用何种方法解题?异或

解题过程

这些方法具体怎么运用?for循环,然后异或,因为异或是相同为0,相异为1,我们就可以这么想——数组中的数依次跟0-N的所有数异或,最后剩下的那个数字就是缺的那个数字

复杂度

  • 时间复杂度:O(n)
  • 空间复杂度:O(1)
​int missingNumber(int* nums, int numsSize) 
{int x = 0;for(int i = 0;i < numsSize;++i){x ^= nums[i];}for(int j = 0;j < numsSize + 1;++j){x ^= j;}​

结尾

结语:本篇文章到这里就结束了,大家一定要自己动手敲一敲,不敲的话容易忘记。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/910223.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/910223.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java Stream详解

Java Stream详解 Stream 是 Java 8 引入的流式数据处理工具&#xff0c;可以像流水线一样对集合数据进行高效操作&#xff08;过滤、转换、统计等&#xff09;。核心特点&#xff1a; 链式操作&#xff1a;支持多个操作串联不修改原始数据&#xff1a;生成新结果支持并行处理…

Java回归循环理解

一、Java循环的四种 1. 传统for循环 - 精确控制的首选 // 遍历数组 int[] numbers {1, 2, 3, 4, 5}; for (int i 0; i < numbers.length; i) {System.out.println(numbers[i]); }// 嵌套示例&#xff1a;矩阵遍历 int[][] matrix {{1, 2}, {3, 4}}; for (int row 0; r…

飞腾D2000金融工控主板,点亮经济高质量发展

近年来&#xff0c;国家不断推出金融行业的政策和法规&#xff0c;推动金融业高质量发展。在国家大力推进金融行业改革和创新的大环境下&#xff0c;金融工控主板市场也迎来了新的发展机遇。随着国产CPU技术的不断突破&#xff0c;以及我国对金融安全重视程度的提高&#xff0c…

SimpleITK——创建nrrd体素模型

在介绍如何生成nrrd前&#xff0c;了解一下为什么医学影像上一般使用nrrd的体素模型&#xff1f; 为什么医学影像上一般使用nrrd的体素模型&#xff1f; 在医学影像领域&#xff0c;‌NRRD&#xff08;Nearly Raw Raster Data&#xff09;格式‌被广泛用于存储体素模型&#x…

Docker容器部署KES

一、安装部署 1&#xff0c;导入镜像 #导入镜像&#xff08;root用户&#xff09; [rootnode docker ]# mv kdb_x86_64_V008R006C009B0014.tar kingbase.tar [rootnode docker]# docker load -i kingbase.tar#查看镜像&#xff08;root用户&#xff09; [rootnode docker]# d…

C++基础练习 sort函数,用于排序函数

题目&#xff1a; https://acm.hdu.edu.cn/showproblem.php?pid2039 解答&#xff1a; #include <iostream> #include <cmath> #include <algorithm> using namespace std;double a[3]; int main(){int n;cin>>n;while(n--){cin>>a[0]>>…

棱镜观察|EMB“重构”卡钳,车企降本压力与Brembo困局

传统制动卡钳市场&#xff0c;正在迎来变革时刻。 一直以来&#xff0c;采埃孚、大陆集团、日立安斯泰莫等外资供应商占据中国乘用车卡钳前装市场&#xff08;包括前制动卡钳和后集成EPB卡钳&#xff09;的半壁江山。同时&#xff0c;伯特利、亚太股份、万向、弗迪等中国供应商…

《颠覆传统:CSS遮罩的图像创意设计指南》

想象有一块神奇的模板&#xff0c;上面有各种形状的镂空区域&#xff0c;当我们将这块模板覆盖在图像上时&#xff0c;只有透过镂空区域才能看到图像的部分&#xff0c;而模板遮挡的地方则被隐藏起来&#xff0c;这便是CSS遮罩的核心概念。遮罩&#xff0c;简单来说&#xff0c…

5.基于神经网络的时间序列预测

近年来&#xff0c;已经开发了一些深度学习方法并将其应用于单变量时间预测场景&#xff0c;其中时间序列由在等时间增量上按顺序记录的单个观测数据组成。 5.1 将深度学习用于时间序列预测的原因 机器学习的目标是提取特征来训练模型。模型将输入数据&#xff08;例如图片&am…

【软考高级系统架构论文】论软件设计方法及其应用

论文真题 软件设计 (Software Design,SD) 根据软件需求规格说明书设计软件系统的整体结构、划分功能模块、确定每个模块的实现算法以及程序流程等,形成软件的具体设计方案。软件设计把许多事物和问题按不同的层次和角度进行抽象,将问题或事物进行模块化分解,以便更容易解决…

什么是水平扩展

什么是水平扩展 在现代系统架构设计中&#xff0c;可扩展性&#xff08;Scalability&#xff09;是衡量系统面对业务增长时应对能力的重要指标。而“水平扩展”&#xff08;Horizontal Scaling&#xff09;&#xff0c;又称为“横向扩展”或“扩容节点”&#xff0c;正是应对高…

掌握openpyxl:Excel自动化处理全指南

openpyxl基础用法 openpyxl 是一个用于处理 Excel 文件&#xff08;.xlsx/.xlsm&#xff09;的 Python 库&#xff0c;支持读取、修改和创建 Excel 文档。以下是其常见用法的详细介绍&#xff1a; 一、基础操作&#xff1a;打开与保存文件 from openpyxl import load_workbo…

FastGPT:开启大模型应用新时代(4/6)

摘要&#xff1a;FastGPT是一种基于大语言模型&#xff08;LLM&#xff09;的知识库问答系统&#xff0c;致力于提供高效、精准的自然语言处理服务。它允许用户构建本地知识库以增强AI的理解能力&#xff0c;通过将用户的问题与知识库信息匹配推理&#xff0c;生成有针对性的回…

在MyBatis中$和#有什么区别

在 MyBatis 中&#xff0c;${} 和 #{} 是两种处理 SQL 参数的占位符&#xff0c;它们在实现机制、安全性、使用场景上存在显著差异。以下是详细对比&#xff1a; 核心区别对比 特性#{}${}底层机制预编译占位符&#xff08;PreparedStatement&#xff09;字符串直接替换安全性…

湖北理元理律师事务所债务优化方案:平衡还款与生活的法律实践

在个人债务问题日益突出的当下&#xff0c;如何科学规划还款路径成为社会性难题。湖北理元理律师事务所基于多年实务经验&#xff0c;提出“可持续债务优化”模型&#xff0c;其核心在于通过法律工具实现三重平衡&#xff1a; 债权债务的法律平衡&#xff1a;严格依据《民法典…

使用 Isaac Sim 模拟机器人

前言 将 2D 激光雷达数据从 Isaac Sim 流式传输至 ROS 2&#xff0c;并通过 RViz 进行可视化。通过激光雷达数据监控机器人与环境的交互&#xff0c;从而在仿真环境中提升机器人的感知能力。 概览 欢迎来到 入门指南&#xff1a;在 Isaac Sim 中模拟您的第一个机器人 课程。我…

quartz 表达式最近10次执行时间接口编写

Nuget安装 <PackageReference Include"CronExpressionDescriptor" Version"2.41.0" /> <PackageReference Include"CronExpressionDescriptor-zh-CN" Version"2.32.0" /> <PackageReference Include"Quartz"…

解锁数据宝藏:数据挖掘之数据预处理全解析

目录 一、引言&#xff1a;数据预处理 —— 数据挖掘的基石二、数据预处理的重要性2.1 现实数据的问题剖析2.2 数据预处理的关键作用 三、数据预处理的核心方法3.1 数据清洗3.1.1 缺失值处理3.1.2 离群点处理3.1.3 噪声处理 3.2 数据集成3.2.1 实体识别3.2.2 冗余处理3.2.3 数据…

React+Taro创建小程序

第一步&#xff1a;首先确认是否安装Node.js和npm 如果已安装Node.js和npm,以下可以查询 node -v npm -v 第二步&#xff1a;安装Taro CLI npm install -g tarojs/cli 第三步&#xff1a;创建项目 taro init my-react-taro-app 然后可以看到&#xff0c;下图 第四步&…

佳能Canon TS3100 Series打印机信息

打印功能 打印速度&#xff1a;黑白约 7.7 页 / 分钟&#xff0c;彩色约 4 页 / 分钟。打印分辨率&#xff1a;最高可达 48001200dpi&#xff0c;墨滴最小间距为 1/4800 英寸&#xff0c;能够保证高质量的输出&#xff0c;使文字清晰、色彩鲜艳。打印宽度&#xff1a;203.2 毫米…