C语言——每日一题(轮转数组)

server/2024/12/22 2:22:24/

一.前言

前不久学习了时间复杂度的概念,便在力扣上刷了一道需要参考时间复杂度的题——轮转数组

https://leetcode.cn/problems/rotate-array/submissions这道题不能使用暴力算法,因为这道题对时间复杂度的要求不能为O(N^2)。因此我们只能使用其他,简便的方法过关。

二.正文

1.1题目描述

1.2暴力算法(思想对,但是不能通过该题)

看到题目,你可能会想通过双重循环将数字一个个遍历到相应位置,这个思路并没有错,只是答案并不能跑过,因为这个方法的时间复杂度是O(N^2),很明显不符合题目要求。如果你想要看,以这个方法在力扣上该如何显示,请看VCR:

虽然能运行,但是不符合题目要求,因此它才显示只通过37个用例,但其实解题思想是没有问题的。

1.3分段逆置

该方法的的思想是:将一组数据,分段逆置,最后再将整个数据进行逆置。好吧,我知道这样讲确实太抽象了。

对于内部的逆转是这样的:

其他的与上面一样的逆转原理。

以下是源代码

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

三.结言

今天的题目分享就到这了,朋友们,咱们下次再见,拜拜~


http://www.ppmy.cn/server/36813.html

相关文章

【负载均衡在线OJ项目日记】项目简介

目录 前言 什么是负载均衡 所用的技术和开发环境 所用技术 开发环境 项目的宏观结构 leetcode 结构 结构 编写思路 前言 从C语言的文章到现在Linux网络部分,我已经涉猎了很多知识;终于在今天我要开始搞项目了,通过项目我也可以开始…

【设计模式】17、iterator 迭代器模式

文章目录 十七、iterator 迭代器模式17.1 user_slice17.1.1 collection_test.go17.1.2 collection.go17.1.3 iterator.go17.1.4 user.go 17.2 book_shelf17.2.1 book_shelf_test.go17.2.2 book_shelf.go17.2.3 iterator.go17.2.4 book.go 十七、iterator 迭代器模式 https://r…

C语言双向链表

前面我们已经学完了单链表的知识点(如果还没有看过的主页有哦~),这篇博客我们就来探讨探讨单链表的孪生弟弟——双向链表。 目录 1.链表的分类 2.双向链表的结构 3.双向链表的实现 3.1 List.h 3.2 List.c 4.书写要点总结说明 4.1为什…

XSS攻击分析---(原理、危害、防御、应急响应)

1、攻击原理 造成XSS漏洞的原因就是,对攻击者的输入没有经过严格的控制,使得攻击者通过巧妙的方法注入恶意指令代码到网页,进行加载并执行。这些恶意网页程序通常是JavaScript,但实际上也可以包括Java, VBScript&…

数据可视化准备:动态识别echarts的横纵坐标数据字段

前言 继上一篇文章 自动选择图表类型:基于数据特征智能决策 分析了如何根据sql和数据结果判断应该自动使用哪种图表类型,本文继续将图表的x轴和y轴横纵坐标识别出来,基本一个二维数据类普通图表就可以直接输出为echarts参数了。 在数据可视…

Android 桌面小组件 AppWidgetProvider

Android 桌面小组件 AppWidgetProvider 简介 小组件就是可以添加到手机桌面的窗口。点击窗口可以进入应用或者进入应用的某一个页面。 widget 组件 如需创建 widget,您需要以下基本组件: AppWidgetProviderInfo 对象 描述 widget 的元数据&#xff0…

解决连接不上VPN问题

解决连接不上VPN问题 错误描述:错误描述: 错误描述: 无法建立计算机与VPN服务器之间的网络连接,因为远程服务器未响应。这可能是因为未将计算机与远程服务器之间的某种网络设备(如防火墙、NAT、路由器等)配…

node.js中的断言

assert.ok(value, [message]):如果value不为真,则抛出一个AssertionError,可选地包含message。 const assert require(assert); assert.ok(true); // 没有错误 assert.ok(false, 这里应该是true); // 抛出 AssertionError: 这里应该是tru…