经典题型---旋转数组
经典题型—旋转数组
文章目录
- 经典题型---旋转数组
- 一、题目
- 二、代码实现
一、题目
给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。
示例 1:
输入: nums = [1,2,3,4,5,6,7], k = 3
输出: [5,6,7,1,2,3,4]
解释:
向右轮转 1 步: [7,1,2,3,4,5,6]
向右轮转 2 步: [6,7,1,2,3,4,5]
向右轮转 3 步: [5,6,7,1,2,3,4]
示例 2:
输入:nums = [-1,-100,3,99], k = 2
输出:[3,99,-1,-100]
解释:
向右轮转 1 步: [99,-1,-100,3]
向右轮转 2 步: [3,99,-1,-100]
提示:
1 <= nums.length <= 105
-231 <= nums[i] <= 231 - 1
0 <= k <= 105
题目理解
右旋可以理解成数组里的元素向右挪动k个单位,而出界的元素再按照正序补到前面的空位。

但是如果当k > numsSize的时候,那就需要使用到余数了,k % numsSize,直到k小于numsSize就可以进行程序操作了。
二、代码实现
法一:数组翻转法
void rotate(int* nums, int numsSize, int k) {int i = 0, j = 0;for (i = 0, j = numsSize - k - 1; i <= j; i++, j--){int tmp = nums[i];nums[i] = nums[j];nums[j] = tmp;}for (i = numsSize - k, j = numsSize - 1; i <= j; i++, j--){int tmp = nums[i];nums[i] = nums[j];nums[j] = tmp;}for (i = 0; i < numsSize; i++){int tmp = nums[i];nums[i] = nums[j];nums[j] = tmp;}
}
优化
void Reverse(int* nums, int begin, int end)
{int i = 0, j = 0;for (i = begin, j = end; i <= j; i++, j--){int tmp = nums[i];nums[i] = nums[j];nums[j] = tmp;}
}
void rotate(int* nums, int numsSize, int k)
{int i = 0, j = 0;Reverse(nums, 0, numsSize - k - 1);Reverse(nums, numsSize - k, numsSize - 1);Reverse(nums, 0, numsSize - 1);
}
不难看出时间复杂度是O(2n),即O(n)
法二:临时数组法
void rotate(int* nums, int numsSize, int k)
{int arr[100000] = { 0 };if (0 == k){;}else{k %= numsSize;while (k >= numsSize){k %= numsSize;}int i = 0, j = 0;for (i = 0, j = numsSize - k; i < k, j <= numsSize - 1; i++, j++){arr[i] = nums[j];}for (i = k, j = 0; i <= numsSize - 1, j < numsSize - k; i++, j++){arr[i] = nums[j];}for (i = 0, j = 0; i < numsSize, j < numsSize; i++, j++){nums[i] = arr[j];}}
}
优化
void rotate(int* nums, int numsSize, int k) {int newArr[numsSize];//变长数组不能初始化for (int i = 0; i < numsSize; ++i) {newArr[(i + k) % numsSize] = nums[i];}for (int i = 0; i < numsSize; ++i) {nums[i] = newArr[i];}
}
这个方法在使用时,笔者掉入了一个很危险的错误,和大家分享出来,希望大家在以后的编程上避开这个坑。**
错误示范:
void rotate(int* nums, int numsSize, int k) {//返回栈空间地址的问题int arr1[100000] = { 0 };if (0 == k){;}else{k %= numsSize;while (k >= numsSize){k %= numsSize;}int i = 0, j = 0;for (i = 0, j = numsSize - k; i < k, j <= numsSize - 1; i++, j++){arr1[i] = nums[j];}for (i = k, j = 0; i <= numsSize - 1, j < numsSize - k; i++, j++){arr1[i] = nums[j];}}nums = arr1;
}
这是一个非常典型的返回栈空间(临时变量地址)的错误,在执行函数过程中,创建了一个临时数组,这个数组存储的就是满足输出形式的数组,但是当函数调用结束后,这块空间就被销毁了,nums反而成了野指针,所以这样的问题一定要避免。
在返回地址的时候要十分小心
相关文章:
经典题型---旋转数组
经典题型—旋转数组 文章目录 经典题型---旋转数组一、题目二、代码实现 一、题目 给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。 示例 1: 输入: nums [1,2,3,4,5,6,7], k 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步…...
vue如何实现登录数据的持久化
Vue.js是一款流行的JavaScript框架,它可以帮助开发者构建高效且易于维护的单页面应用程序。在Vue.js中,实现登录数据的持久化是一个重要的任务,因为它可以帮助用户保持登录状态并避免频繁的登录操作。在本文中,我们将讨论Vue.js如…...
【Unity3D编辑器开发】Unity3D中实现Transform组件拓展,快速复制、粘贴、复原【非常实用】
推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址我的个人博客 大家好,我是佛系工程师☆恬静的小魔龙☆,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 一、前言 在开发中,常常会遇到频繁复制粘贴物体的坐标、旋转…...
求解仿射变换矩阵
仿射变换是图形学中经常用到的方法,通常但是仿射变换的系数是未知的,需要找到变换前后的三对对应点进行求解。 from affine import Affine import numpy as np参考文献 矩阵最小二乘法求解仿射变换矩阵 def solve_affine(init_points, goal_points) -&…...
【每日一题】—— 最大素因子
🌏博客主页:PH_modest的博客主页 🚩当前专栏:每日一题 💌其他专栏: 🔴 每日反刍 🟡 C跬步积累 🟢 C语言跬步积累 🌈座右铭:广积粮,缓称…...
【JavaEE】JUC 常见的类 -- 多线程篇(8)
JUC 常见的类 1. Callable 接口2. ReentrantLock3. 原子类4. 线程池5. 信号量 Semaphore6. CountDownLatch 1. Callable 接口 Callable Interface 也是一种创建线程的方式 Runnable 能表示一个任务 (run方法) – 返回 voidCallable 也能表示一个任务(call方法) 返回一个具体的…...
java项目运行时信息获取
大体思路如下,想要获取启动时处理器数量、jvm 相关信息,操作系统信息、运行机器信息 运行机器信息 import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.lang.invoke.MethodHandles;/*** 机器工具类*/ public abstract class ServerU…...
【LeetCode】71. 简化路径
1 问题 给你一个字符串 path ,表示指向某一文件或目录的 Unix 风格 绝对路径 (以 / 开头),请你将其转化为更加简洁的规范路径。 在 Unix 风格的文件系统中,一个点(.)表示当前目录本身…...
操作系统【OS】进程的控制【进程的创建、终止、阻塞、唤醒】
定义和过程 对应事件 创建 允许一个进程创建另一个进程允许子进程继承父进程所拥有的资源创建进程的过程如下: 申请一个空白的 PCB,并向 PCB 中填写一些控制和管理进程的信息,比如进程的唯一标识等;为该进程分配运行时所必需的…...
写一个简单的解释器(2) 构建标记流
确定标记类型 分为几个大类: 用户符号(类型/标识符/数字/字符串…)关键字 (流程控制和定义符)括号 (这里暂时认为 [] 属于括号)分号 上述四类标记基本囊括了 vc \texttt{vc} vc 中的所有最小单元的类型,但是因为构…...
Leetcode1833. 雪糕的最大数量
Every day a Leetcode 题目来源:1833. 雪糕的最大数量 解法1:贪心 排序 本题唯一的难点在于计数排序。 计数排序详解:C算法之计数排序 为了尽可能多的买到雪糕,我们选择从价格低的雪糕开始买,统计能够买到的雪糕…...
idea 里 没有svn选项的处理办法
总结一下没有svn选项的几种情况: 情况1:IntelliJ IDEA打开带SVN信息的项目不显示SVN信息,项目右键SVN以及图标还有Changes都不显示解决方法 在VCS菜单中有个开关,叫Enabled Version Control Integration,在打开的窗口…...
基于SpringBoot的招生管理系统
基于SpringBoot的招生管理系统的设计与实现~ 开发语言:Java数据库:MySQL技术:SpringBootMyBatisVue工具:IDEA/Ecilpse、Navicat、Maven 系统展示 主页 登录界面 管理员界面 用户界面 摘要 基于SpringBoot的招生管理系统是一款现…...
01、MySQL-------性能优化
目录 一、影响性能的相关因素存储过程: 二、sql优化1>、Mysql系统架构2>、引擎区别: 3>、索引1、什么是索引?联合主键索引理解:索引长度理解:什么是慢查询? 1)、索引理解2)…...
Flutter - APP跳转高德、百度、腾讯、谷歌地图
demo 地址: https://github.com/iotjin/jh_flutter_demo 代码不定时更新,请前往github查看最新代码 这里介绍的是不需要自己开发地图,直接通过给定的经纬度,跳转到三方地图APP调用导航的方式 一种是写的工具类,一种是通过调用三方…...
Flyway Desktop updated
Flyway Desktop updated 为比较工件序列化和反序列化添加了额外的调试日志记录。 Flyway Desktop现在将记住以前用于创建项目和匹配克隆的位置。 新的脱机许可工作流现在已在Microsoft Windows上启用。 现在,在配置目标数据库列表时,环境ID是可见的。 现…...
阿里云短信服务设置操作项目
在这里插入图片描述...
学习笔记|串口通信实战|简易串口控制器|sprintf函数|STC32G单片机视频开发教程(冲哥)|第二十一集(下):串口与PC通信
目录 3.串口通信实战实操简易的工作原理Tips:sprintf函数简介 总结课后练习 3.串口通信实战 做一个简易串口控制器。发送对应指令,让板子做相应的事情,或者传输数据(文本模式下发送,不要选择HEX)。 1.串口发送字符Ax\…...
卷积神经网络CNN学习笔记-卷积计算Conv2D函数的理解
目录 1.全连接层存在的问题2.卷积运算3.填充(padding)3.1填充(padding)的意义 4.步幅(stride)5.三维数据的卷积运算6.结合方块思考7.批处理8.Conv2D函数解析9.conv2d代码9.1 stride19.2 stride2 参考文章 1.全连接层存在的问题 在全连接层中,相邻层的神经元全部连接…...
收藏,安装报错信息汇总,MacOS上安装Adobe等软件/插件报错问题解决合集
打开允许“允许任何来源” 如何打开允许任何来源?在 Finder 菜单栏选择 【前往】 – 【实用工具 】,找到【终端】程序,双击打开,在终端窗口中输入:sudo spctl --master-disable 输入代码后,按【return 回车…...
从零玩转智能氛围灯:基于ESPHome与WS2812B的个性化灯光方案
1. 为什么选择ESPHome与WS2812B打造智能氛围灯? 如果你厌倦了传统智能灯只能调节亮度和颜色的单调功能,想要实现音乐律动、电影同步或者根据时间自动切换的沉浸式灯光效果,那么ESPHome搭配WS2812B灯带绝对是你的不二之选。我最初接触这个组合…...
2025届学术党必备的十大降AI率方案实际效果
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 维普 AIGC 检测系统是用于学术原创性审查的工具,它借助分析文本生成概率、语言模…...
详解python运行三种方式
方式一交互式编程交互式编程不需要创建脚本文件,是通过 Python 解释器的交互模式进来编写代码。linux上你只需要在命令行中输入 Python 命令即可启动交互式编程,提示窗口如下:12345$ pythonPython 2.7.6 (default, Sep 9 2014, 15:04:36) [GCC 4.2.1 Com…...
如何高效管理个人数字记忆:WeChatMsg聊天记录分析与归档实用指南
如何高效管理个人数字记忆:WeChatMsg聊天记录分析与归档实用指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trendin…...
AI 间接提示注入攻击成首要安全风险,企业与个人如何应对?
ZDNET 要点总结恶意的网页提示能在未输入信息时利用 AI,间接提示注入已成为大型语言模型(LLM)首要安全风险。别以为 AI 聊天机器人完全安全或无所不知。人工智能(AI)及其对企业和消费者的益处是今年会议和峰会热门话题…...
当Zabbix Agent装不了怎么办?用SNMP监控Linux服务器的CPU、内存和磁盘(附常用OID清单)
无Agent监控方案:SNMP在Linux服务器性能监控中的实战应用 想象一下这样的场景:凌晨三点,你的手机突然响起刺耳的告警铃声。某台关键业务服务器CPU负载飙升,但偏偏这台机器因为合规限制无法安装Zabbix Agent。此时,SNMP…...
音频变压器核心技术解析:噪声隔离、阻抗匹配与信号平衡转换
引言在专业音频系统、广播设备、会议系统以及Hi-Fi音响中,音频变压器往往是一个不起眼却至关重要的元件。它利用电磁耦合原理传输信号,同时实现输入与输出之间的电气隔离。与普通的电力变压器不同,音频变压器针对20Hz~20kHz的人耳可听频段进行…...
终极赛博朋克2077存档编辑器:从新手到专家的完全指南
终极赛博朋克2077存档编辑器:从新手到专家的完全指南 【免费下载链接】CyberpunkSaveEditor A tool to edit Cyberpunk 2077 sav.dat files 项目地址: https://gitcode.com/gh_mirrors/cy/CyberpunkSaveEditor 赛博朋克2077存档编辑器是一个强大的开源工具&a…...
面试真题集(八):多GPU编程与通信
引言 单卡优化是基础,多卡并行才是工业界常态。本专题精选20道面试真题,聚焦多GPU编程、NCCL通信、拓扑感知、分布式训练优化等核心内容,助你攻克多卡编程的难关。 一、选择题(6题) 1.1 关于多GPU编程,下列说法错误的是?(⭐⭐) A. 不同GPU的显存空间彼此独立,不能直…...
从电机控制到电源设计:我是如何把PMSM的扫频“黑科技”复用到移相全桥DCDC上的
从电机控制到电源设计:PMSM扫频技术在移相全桥DCDC中的跨界应用 当我在调试一台永磁同步电机(PMSM)的速度环时,偶然发现Simulink扫频技术竟然能完美复用到移相全桥DCDC电源的电压环设计中。这种跨领域的知识迁移不仅节省了大量时间…...
