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

那些影视解析网站怎么做的四川省人民政府官网

那些影视解析网站怎么做的,四川省人民政府官网,什么网站做的好看的,企业品牌网站建设文章目录 题目暴力求解空间换时间三段逆置总结 题目 LeetCode 189.轮转数组 给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。 输入: nums [1,2,3,4,5,6,7], k 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步: [7,1,2,3,4,5…

文章目录

    • 题目
    • 暴力求解
    • 空间换时间
    • 三段逆置
    • 总结


题目

LeetCode 189.轮转数组

给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。

输入: 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]

轮转数组是一种将数组中元素向右移动 k 个位置的操作。具体地,我们将数组的最后 k 个元素移动到数组的开头,而数组的前 n-k 个元素向后移动 k 个位置。

说简单点就是把后面的元素,依次转移到前面。


暴力求解

算法思路:

  1. 定义一个临时变量 tmp,用来存放数组最后的元素7
  2. 把数组前 n-1 个值往后挪
  3. 把 tmp 的值放入前面空位置中去

这样就完成了 1 次轮转,如果要轮转 k 次,就需要循环 k 次就完成了

第一步:
在这里插入图片描述
第二步:

在这里插入图片描述
第三步:
在这里插入图片描述
代码实现:

void rotate(int* nums, int numsSize, int k)
{k %= numsSize;//防止k大于numsSizeint tmp = 0;for (int i = 0; i < k; i++){tmp = nums[numsSize - 1];for (int j = numsSize - 1; j > 0; j--){nums[j] = nums[j - 1];}nums[0] = tmp;}
}

时间复杂度:O(N^2) 最坏情况
空间复杂度:O(1)


空间换时间

算法思路:

  1. 新开辟一个数组
  2. 把后 k 个元素放到新数组的前面
    3 .再把前 n-k 个元素放到新数组的后面(n是数组中元素总个数 也就是题目中的参数 numsSize)

在这里插入图片描述

代码实现:

void rotate(int* nums, int numsSize, int k)
{if (k > numsSize){k %= numsSize;}int* tmp = (int*)malloc(sizeof(int) * numsSize);memcpy(tmp, nums + numsSize - k, sizeof(int) * k);memcpy(tmp + k, nums, sizeof(int) * (numsSize - k));memcpy(nums, tmp, sizeof(int) * (numsSize));free(tmp);tmp = NULL;
}

时间复杂度:O(N)
空间复杂度:O(N)


三段逆置

算法思路:

  1. 对前 n-k 个逆置
  2. 对后 k 个逆置
  3. 整体逆置

封装一个reverse逆置函数,进行操作。reverse 函数用于反转数组中指定范围的元素,这里使用了双指针来实现。

在这里插入图片描述
代码实现:

void reverse(int* arr, int left, int right)
{while (left < right){int tmp = arr[left];arr[left] = arr[right];arr[right] = tmp;left++;right--;}
}void rotate(int* nums, int numsSize, int k) 
{if(k>numsSize){k%=numsSize;}reverse(nums, 0, numsSize-k-1);//第一段逆置reverse(nums, numsSize-k, numsSize-1);//第二段逆置reverse(nums, 0, numsSize-1);//第三段逆置
}

时间复杂度:O(N)
空间复杂度:O(1)


总结

最优算法:三段逆置>空间换时间>暴力求解

评判哪个方法为最优解,一般是关注该方法运行时的时间复杂度。时间复杂度低,算法计算时间越快,则为做优算法。
对于空间换时间的方法,虽然运行消耗内存增加,但一般不太会关注消耗内存的多少,现在随着技术发展的越来越快,对于内存的成本控制的也越开越低。所以用空间换时间,还是划算的。

http://www.sczhlp.com/news/27502/

相关文章:

  • 香港国际建设网站首页怎么弄一个自己的网站
  • 北京企业宣传片制作公司搜索引擎优化的分类
  • 手机如何建设网站大一网页设计作业成品
  • hexo vs wordpress百度关键词优化公司哪家好
  • 一般做网站多少钱国家免费培训机构
  • 网页设计资料下载网站百度seo点击器
  • 如何搜名字搜到自己做的网站淘宝宝贝关键词排名查询工具
  • 新网站如何做友情链接网站alexa排名查询
  • 【刷题笔记】树形 DP
  • 给自己的网站做代言百度知道一下首页
  • 柳市做网站的公司网站关键词优化软件效果
  • 哪个企业的网站做的比较好女排联赛最新排行榜
  • 本机电脑怎么做网站360优化大师历史版本
  • 做网站是com好还是cn好百度新闻网页
  • 商城网站建设定制网站建设天津百度推广排名优化
  • 呼叫中心外包长春seo排名公司
  • 怎么做免费网站如何让百度收录定制开发公司
  • 视频网站直播怎么做的网站链接交易
  • 【自学嵌入式:stm32单片机】I2C通信外设
  • 如何优雅统计知识库文件个数与子集下不同文件夹文件个数
  • AWS Builder Center:开发者社区新家园,一站式技术资源与协作平台
  • 计数练习
  • 大连市中小企业做网站政府补贴黄页推广平台有哪些
  • 专门做搜索种子的网站泉州百度竞价推广
  • 泉州企业网站建设搜索引擎营销优化策略有哪些
  • pytest入门
  • 微软行业案例:英格兰足球超级联赛(Premier League) - 教程
  • 高压差分探头:高压电子测量的精准利器
  • 阿里云ecs,云控制台磁盘扩容,需在服务器执行命令
  • 最常用的规划网站郑州网络推广服务