当前位置: 首页 > news >正文

力扣(LeetCode) ——轮转数组(C语言)

题目:轮转数组

给定一个整数数组 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:

在这里插入图片描述

最终代码:

void rotate(int* nums, int numsSize, int k) 
{k = k % numsSize;while(k--){int temp = nums[numsSize-1];for(int i = numsSize-1;i>0;i--){nums[i] = nums[i-1];}nums[0] = temp;}
}

解题思路2:

在这里插入图片描述

最终代码:

void revolve(int* nums,int left,int right)
{while(left<right){int temp = nums[left];nums[left] = nums[right];nums[right] = temp;left++;right--;}
}void rotate(int* nums, int numsSize, int k) 
{k = k % numsSize;revolve(nums,0,numsSize-1-k);revolve(nums,numsSize-k,numsSize-1);revolve(nums,0,numsSize-1);
}
http://www.lryc.cn/news/597741.html

相关文章:

  • 第一层nginx访问url如何透传到第二层nginx
  • 【SQLServer】Microsoft SQL Server远程版本信息泄漏
  • Java学习---Spring及其衍生(上)
  • 分布式限流算法与组件
  • Android模块化实现方案深度分析
  • 【读代码】李沐团队开源音频大模型 Higgs Audio V2
  • 二、计算机网络技术——第4章:网络层
  • 4️⃣字典(dict)速查表
  • 三大论坛联动,2025合成生物学盛会助力生物制造高质量发展
  • 半导体 CIM(计算机集成制造)系统
  • Hexo - 免费搭建个人博客02 - 创建个人博客
  • 智能办公如何创建e9流程
  • ubuntu24的一些小问题
  • Spring事务注解详解:确保你的应用数据的一致性
  • Python Day22 - 复习日
  • Python-Pytorch编码习惯
  • C++ BFS实例:从入门到实战
  • 设计模式 八:原型模式 (Prototype Pattern)
  • java设计模式 -【装饰器模式】
  • AI营销核心技术解析:运作机制与行业应用实例
  • 在模拟器上实现 GRE 实验
  • HCIP一二章笔记
  • 动态路由协议基础
  • HF86611_VB1/HF86611Q_VB1:多通道USB HiFi音频解码器固件技术解析
  • 0基础法考随手笔记 02(刑诉法专题04 辩护与代理)
  • 音视频中一些常见的知识点
  • 机器学习与视觉结合开发基础
  • 设备虚拟化技术
  • 漏洞扫描系列03:导出PDF/HTML报告
  • 如何Visual Studio 的配置从 Qt-Debug 切换到 x64-Debug