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

虚拟主机 域名 和网站关系/热点军事新闻

虚拟主机 域名 和网站关系,热点军事新闻,微信开发者工具app,星乐seo网站关键词排名优化题目 给定一个数组 nums&#xff0c;编写一个函数将所有 0 移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序。 请注意 &#xff0c;必须在不复制数组的情况下原地对数组进行操作。 数据范围 1 < nums.length < 104 -231 < nums[i] < 231 - 1 样例 示例…

题目

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

数据范围

1 <= nums.length <= 104
-231 <= nums[i] <= 231 - 1

样例

示例 1:

输入: nums = [0,1,0,3,12]
输出: [1,3,12,0,0]

示例 2:

输入: nums = [0]
输出: [0]

题解

博主题解(O(n)略慢于官方题解,但空间复杂度超过百分之99,且思路简单)

public static void moveZeroes(int[] nums) {//第一次遍历处理数据,得到非目标位0的数量int len=nums.length;//记录已遍历0数目int tz=0;for(int i=0;i<len;i++){if(nums[i]==0){tz++;continue;}nums[i-tz]=nums[i];}for(int i=0;i<len;i++){if(i==len-tz){nums[i]=0;tz--;}System.out.print(nums[i]+" ");}}

官方题解 (O(n)双指针,双指针)

class Solution {public void moveZeroes(int[] nums) {int n = nums.length, left = 0, right = 0;while (right < n) {if (nums[right] != 0) {swap(nums, left, right);left++;}right++;}}public void swap(int[] nums, int left, int right) {int temp = nums[left];nums[left] = nums[right];nums[right] = temp;}
}作者:力扣官方题解
链接:https://leetcode.cn/problems/move-zeroes/solutions/489622/yi-dong-ling-by-leetcode-solution/
来源:力扣(LeetCode

思路

这道题整体思路简单,但题目提到,不能新建数组,那么目的很明确了,就是要求你在O(1)的空间复杂度和O(n)的时间复杂度完成这道题。

博主采用的思路很简单,不管原始数组如何,最后得到的数组形式是一样的,前面一串非0数字,最后几个连续的0,那么就不需要考虑交换的逻辑,而是去把数字放到他最后应该存在的位置即可。这个很容易实现,使用tz存储目前遍历位置已经出现过0的数量,然后将非0数字往前移动就好。在遍历的过程中顺便记录0的个数,最后再把0填充到数组末端即可。

官方题解的思路需要熟悉双指针的思路,双指针有两种常见思路。第一种两个指针同时从一侧出发,类似快慢指针。第二种两个指针分别从两侧出发。这道题我们经过判断后,选择第一种,left用来存储非零数字目前应该存储的位置,right用来作为枚举的效果。通过交换 left 和 right 的元素,确保left 左侧全是非零元素(且顺序不变),left 和 right 之间是零(如果有)。

整体来说,对于没接触过或不熟悉双指针的人来说,官方题解虽然优雅,但还是具有一定的思维难度,大家多联系即可。

http://www.whsansanxincailiao.cn/news/32019708.html

相关文章:

  • 云服务器搭建网站教程/百度营销是什么
  • 西安知名网站建设公司排名/怎么创建网站
  • 一个域名可以做几个网站/天津网站优化
  • 虚拟空间网站ftp如何差异化同步/上海优化外包公司排名
  • 郑州做网站好的公/企业软文怎么写
  • 教人做衣服得网站有哪些/长沙靠谱关键词优化公司电话
  • 一家只做卫生巾的网站/手机怎么搭建网站
  • 做游戏钓鱼网站/百度广告联盟收益
  • 四川省住建厅特种作业证报名/绍兴seo排名
  • 华为云自助建站/青岛新闻最新消息
  • 做一个交友网站怎样做需要多少资金/中国搜索引擎排名
  • 深圳企业网站建设设计制作方案/百度做网站推广的费用
  • 网站源代码怎么上传/百度seo教程视频
  • 广州海珠区地图/郑州网站优化
  • 汕头网站关键排名/网络营销推广方案前言
  • 口碑好的网站建设服务/完整企业网站模板
  • 网站建设运行环境/如何销售自己产品方法有哪些
  • 泉州网站建设方案外包/搜索 引擎优化
  • 网页微信版下载/win7系统优化大师
  • 淘宝联盟建网站/建立一个网站需要多少钱
  • 焦作市建设工程网站/html底部友情链接代码
  • 美国网站人肉收做/上海网络seo
  • 青岛建网站哪个好/厦门seo厦门起梦
  • 营销型网站建设标准/站长之家seo一点询
  • 小型商城网站/怎么制作网站教程
  • 微网站开发工具/网店代运营商
  • 网站建设公司方案/百度推广一天费用200
  • 深圳官网建设公司/西安seo网站关键词优化
  • 临沂手机端建站模板/湖南seo优化哪家好
  • 龙华做棋牌网站建设哪家好/上海短视频seo优化网站