c语言:解决数组元素右旋问题,时间复杂度O(N)

news2024/9/23 7:33:03

题目:

给一个数组,如【1,2,3,4,5,6,7】,k=3。

要求得到新数组【5,6,7,1,2,3,4】。


 方法一,思路和代码:

void rotate(int* nums, int numsSize, int k)
{
	while (k)
	{
		int tmp = nums[numsSize - 1];//创建一个临时变量存放最后一个数
		for (int end = numsSize - 2; end >= 0; --end)//循环数组元素个数的n-1次,因为最后一个数要前置,不用管
		{
			nums[end + 1] = nums[end];//后一个数被前一个数替代,n-1个数右移一次
		}
		nums[0] = tmp;//将最后一个数放在首元素的位置
		k--;//循环k次
	}
}

方法二,思路: 

//方法二(时间复杂度:O(N),空间复杂度:O(N))
//以空间换时间,再创建一个数组,存放要右旋的变量。
//举例说明:【1,2,3,4,5,6,7】,右旋三
//将后三个(k个),存放在一个数组中,【5,6,7】,再右移动四个数的位置(n-k)【1,2,3,4】
//也就成了【5,6,7,1,2,3,4】(这个方法比较简单好想,这里不做代码展示)

方法三,思路和代码(最牛): 

//方法三(牛),时间复杂度和空间复杂度都最小
//思路:1.后k个逆置
//      2.前n-k个逆置
//      3.最后整体逆置
//如【1,2,3,4,5,6,7】,k=3
//1.【1,2,3,4,7,6,5】
//2.【4,3,2,1,7,6,5】
//3.【5,6,7,1,2,3,4】
void Reverse(int* nums, int left, int right)//逆置代码
{
	while (left < right)
	{
		int tmp = nums[left];
		nums[left] = nums[right];
		nums[right] = nums[left];
		left++;
		right--;
	}
}
void rotate(int* nums, int numsSize, int k)
{
	if (k >= numsSize)//当k大于数组长度时,对k%数组长度,取余,例如k=13,numsSize=7,k=6和k=13是一样的,但不取余的话会运行出错
	{
		k %= numsSize;
	}
	Reverse(nums, numsSize-k, numsSize - 1);//后面逆置
	Reverse(nums, 0, numsSize -k-1);//前面逆置
	Reverse(nums, 0, numsSize - 1);//整体逆置

}

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

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

相关文章

CPS:实现销售和广告的完美结合

随着互联网的快速发展&#xff0c;电商行业呈现出爆炸性的增长。在这个充满竞争的市场中&#xff0c;如何有效地吸引和引导消费者购买产品&#xff0c;成为电商企业成功的关键。而CPS&#xff08;Cost Per Sales&#xff09;作为一种创新的广告模式&#xff0c;正逐渐成为电商行…

cadence virtuoso layout 创建保护环 GuardRing

本文使用的是smic130nm工艺库 参考文章&#xff1a;基于IC617创建保护环GuardRing&#xff08;一&#xff09;_版图保护环的意义-CSDN博客 SP GuardRing 按O&#xff0c;M1_SUB columns5 画出版图 量出各图层之间的间距&#xff0c;比如&#xff1a; CT-CT 0.18 CT-AA 0.0…

十大跑步运动耳机品牌,适合运动时戴的蓝牙耳机有哪些?

​运动耳机不仅具备出色的音质和舒适度&#xff0c;还有着强大的防汗防水功能&#xff0c;可以满足你在运动中的各种需求。无论你是喜欢户外跑步&#xff0c;还是喜欢室内健身&#xff0c;运动耳机都能为你提供优秀的音乐动力&#xff0c;让你更加享受运动的过程。那么怎么去选…

自动生成Form表单提交在苹果浏览器中的注意事项

以下是本人在公司旧系统中看到的该段代码 function Post(URL, PARAMTERS) {//创建form表单var temp_form document.createElement("form");temp_form.action URL;//如需打开新窗口&#xff0c;form的target属性要设置为_blanktemp_form.target "_blank"…

Java: 实现电影信息管理系统 (javaBean)

文章目录 电影信息系统1. 将JavaBean数据类封装好2.业务逻辑类3.测试类&#xff08;main函数类&#xff09; 电影信息系统 需求&#xff1a; 展示系统中的全部电影&#xff08;每部电影展示、名称、平分&#xff09;。允许用户根据电影编号&#xff08;id&#xff09;查询出某…

火山引擎 DataLeap 计算治理自动化解决方案实践和思考

更多技术交流、求职机会&#xff0c;欢迎关注字节跳动数据平台微信公众号&#xff0c;回复【1】进入官方交流群 【导读】本文旨在探讨火山引擎 DataLeap 在处理计算治理过程中所面临的问题及其解决方案&#xff0c;并展示这些解决方案带来的实际收益。主要内容包括&#xff1a;…

使用 Electron 来替代本地调试线上代理的场景

Cookie Samesite 问题 https://developers.google.com/search/blog/2020/01/get-ready-for-new-samesitenone-secure?hlzh-cnhttps://www.chromium.org/updates/same-site/https://github.com/GoogleChromeLabs/samesite-exampleshttps://releases.electronjs.org/releases/s…

Labview实现wav音乐播放

准备音频文件&#xff1a;将要播放的声音文件准备好&#xff0c;是.wav格式。 图形化如下&#xff1a; 内部逻辑如下&#xff1a;

名师助阵龙讯旷腾PWmat+半导体缺陷培训暨半导体缺陷计算大赛

半导体缺陷计算大赛 选拔赛截止日期&#xff1a;11月23日 参与杭州线下培训直接跳过选拔赛 大赛亮点 线上免费培训、线下限时领取免费名额 线下杭州培训可直通决赛&#xff0c;跳过选拔赛 线上培训有3次机会参与考试进入决赛 已购/未购用户均可参加、无身份限定 使用Mc…

新程出海:TikTok电商带货的6大注意事项

当下&#xff0c;越来越多的商家借助海外抖音TikTok平台实现电商带货。但是&#xff0c;由于海外市场和文化环境的不同&#xff0c;如果没有正确的操作方法和注意事项&#xff0c;会存在诸多问题和挑战。因此&#xff0c;接下来新程出海为您介绍海外抖音TikTok电商带货的注意事…

大数据-之LibrA数据库系统告警处理(ALM-12041 关键文件权限异常)

告警解释 系统每隔一个小时检查一次系统中关键目录或者文件权限、用户、用户组是否正常&#xff0c;如果不正常&#xff0c;则上报故障告警。 当检查到权限等均正常&#xff0c;则告警恢复。 告警属性 告警ID 告警级别 可自动清除 12041 严重 是 告警参数 参数名称 …

mysql 中with的用法(1)

mysql 中with的用法 1、案例一&#xff1a; 建表&#xff1a; CREATE TABLE employees (employee_id INT PRIMARY KEY,first_name VARCHAR(50),last_name VARCHAR(50),salary INT );INSERT INTO employees (employee_id, first_name, last_name, salary) VALUES (1, John, Do…

Springboot+vue的人力资源管理系统(有报告)。Javaee项目,springboot vue前后端分离项目

演示视频&#xff1a; Springbootvue的人力资源管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot vue前后端分离项目 项目介绍&#xff1a; 本文设计了一个基于Springbootvue的前后端分离的企业资产管理系统&#xff0c;采用M&#xff08;model&…

Kotlin Multiplatform稳定版本发布:加速跨平台开发的新里程碑

Kotlin Multiplatform稳定版本发布&#xff1a;加速跨平台开发的新里程碑 引言 在最新的消息中&#xff0c;JetBrains团队宣布Kotlin Multiplatform&#xff08;KMP&#xff09;将于2023年10月稳定发布。这一消息对于广大开发者来说毫无疑问是一个令人振奋的消息。KMP的正式生…

【Java】集合(一)单列集合List

1.集合 可以动态保存任意多个对象&#xff0c;并提供了一系列的操作对象的方法&#xff1a;add、remove、set、get等。 2.集合框架体系 分为两大类&#xff1a; 单列集合和双列集合 3.List接口基本介绍 List接口是Collection接口的子接口 List集合类中元素有序&#xff0…

2024京津冀人工智能展会(世亚智博会)展现“中国智造”高端技术

2024京津冀人工智能展会&#xff08;简称:世亚智博会&#xff09;已正式定档2024年6月28-30日&#xff0c;将启用北京亦创会展中心的一层全部展厅&#xff0c;预计展出面积达6万平方米&#xff0c;吸纳全球超过800家展商&#xff0c;展现“中国智造”的尖端理念与高端技术&…

制作企业期刊的网站,小白也能做出超吸睛的期刊

制作企业期刊的网站&#xff0c;对于许多企业来说&#xff0c;是一项既重要又具有挑战性的任务。然而&#xff0c;如果你是一位初学者或者是一位小白&#xff0c;也不用过于担心。按照小编说的步骤去做&#xff0c;你也能制作出吸引人的电子期刊 首先&#xff0c;你需要选择一个…

操作系统(三)进程和线程的基础知识

文章目录 前言进程和线程进程进程的状态进程控制块(PCB&#xff0c;Process Control Block)进程的上下文切换 线程线程的实现 进程加载进程等待和退出等待退出 优先级控制进程调试支持定时 小结 前言 本文主要涉及操作系统的简介、硬件结构、内存管理、进程管理、文件系统、设…

【Proteus仿真】【STM32单片机】停车场车位管理系统

文章目录 一、功能简介二、软件设计三、实验现象联系作者 一、功能简介 本项目使用Proteus8仿真STM32单片机控制器&#xff0c;使用按键、LED、蜂鸣器、LCD1602、红外传感器、74HC595模块等。 主要功能&#xff1a; 系统运行后&#xff0c;LCD1602显示进入、驶出、剩余车位数…

什么是光电耦合器?如何选择型号及种类

光电耦合器(英文缩写为OC)亦称光电隔离器&#xff0c;简称光耦&#xff1b;以光为媒介传输电信号&#xff1b;它对输入、输出电信号有良好的隔离作用&#xff0c;是目前种类最多、用途最广的光电器件之一&#xff1b;所以&#xff0c;它在各种电路中得到广泛的应用。 光耦合器…