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

怎样做国际网站计算机入门基础知识

怎样做国际网站,计算机入门基础知识,网络安全企业,快手自媒体平台题目:给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。 示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0]示例 2: 输入: …

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

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

示例 1:

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

示例 2:

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

第一种解题方法+代码:

第一种方法时间复杂度为O(n)。

代码:

class Solution {public void moveZeroes(int[] nums) {/*解题思路:双指针遍历数组1.使用一个指针 i 遍历数组 nums。2.使用另一个指针 j 记录非零元素应该放置的位置。3.当遇到非零元素时,将其移动到 j 指向的位置,并将 j 向前移动。4.遍历完成后,从 j 开始到数组末尾的位置全部填充 0。*///记录非0元素存放的位置int j = 0;//遍历数组for(int i = 0;i<nums.length;i++){if(nums[i] != 0){nums[j] = nums[i];j++;}}//填充0while(j<nums.length){nums[j] = 0;j++;}}
}

第二种解题方法+代码:

代码:

class Solution {public void moveZeroes(int[] nums) {/*解题思路:类似冒泡排序遍历数组nums,查找到0元素和非0元素时,交换它们的位置,将0元素向后移,一直到0元素都在数组的末尾*///嵌套for循环遍历numsfor(int i = 0;i<nums.length;i++){for(int j = 0;j<nums.length -i -1 ;j++){//查找到0元素和非0元素时,交换它们的位置if(nums[j] == 0 && nums[j+1] != 0){//类似于交换2杯水,需要一个中间变量int temp = nums[j];nums[j] = nums[j+1];nums[j+1] = temp;   }}}}
}

 

第二种解题方法效率比较低,需要花费的时间久(嵌套for循环的时间复杂度为O(n^2))。

总结:个人认为双指针遍历循环更简单高效,时间空间复杂度更小,因此个人更加推荐第一种解题方法。第二种方法类似于冒泡排序,在这篇博客中提供一种解题思路。继续加油~

http://www.yayakq.cn/news/28533/

相关文章:

  • 工作室网站建设的意义wordpress布局切换功能
  • 优秀网站ui设计一般做网站宽高多少
  • 好的设计作品网站最新网站建设方案
  • 政务网站的建设原则现在 做网站 技术路线
  • 百度推广怎么做网站的优化网站后台不能粘贴文章
  • 大连比较好的网站公司忻州免费建网站
  • 塔式服务器主机建网站通州郑州阳网站建设
  • 金泉网做网站推广创办一个网站的流程
  • 买房网站怎么做建设部网站官网证书编号
  • 百度推广怎么做网站广西的网络公司
  • 国外一个做ppt的网站北京好网站制作公司哪家好
  • 如何选择网站开发公司大型网站制作丹阳网站建设
  • 汕头免费自助建站模板服务 信誉好的网站制作
  • 一个网络空间做两个网站广东省建筑安全员证查询官网
  • 如何拿高权重网站外链进行互换?给公司做网站需要多少钱
  • 怎么能创建自己的网站wordpress edit.php
  • 建设网站基本步骤做网站需要用到ps吗
  • 在火炉做网站公园坐什么车黄金网站
  • 网站建设 算什么品玩 wordpress主题
  • 德州网站建设哪家好网站移动端适配怎么做
  • 中山火炬开发区建设局网站手机兼职赚钱软件
  • 在海外做网站 卖东西做番号网站的 违法
  • 郑州做网站公司电话dw可以做网站吗
  • 标准件做网站推广效果怎么样公司网站有收录没排名
  • 网站建设选亿企网络可以在什么网站做二建题目
  • 网站后台系统访问网站服务器打不开
  • 做导购类网站各级院建设网站的通知
  • 创新的江苏网站建设新网站建设流程图
  • 为网站网站做代理被判缓刑即时设计app下载
  • 手机网站模板设计软件软件企业网站建设栏目结构图