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

郑州做网站九零后找代写文章写手

郑州做网站九零后,找代写文章写手,备案网站 cdn,流放之路做装备词缀网站难度:简单题 题目 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。 思路: 一开始想,从前往后遍历&am…

难度:简单题

题目

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

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

思路:

一开始想,从前往后遍历,遇到0就挪到最后。类似于冒泡的思想,但是这样做的话时间复杂度可能是 三次方。

再想,从前往后遍历,利用 stl-vector 的特性,遇到0就从这个vector里面删除当前元素,但是删除这个元素的话,该vector数组结构会发生变化,即当前下标指向的自动变为下一个元素,所以下标这里要减1。

代码:

class Solution {
public:void moveZeroes(vector<int>& nums) {// 要保持非零元素的相对顺序,不能排序!// 依次遍历,遇到0元素,则用冒泡排序的思想挪到最后 时间复杂度 三次方??// 思路,依次遍历,如果遇到0,则从vector中删掉该元素,并记录删了几个,最后添上去// 遍历时删元素会不会使数组下标发生变化?会使数组结构发生变化!int i = 0;int n = 0;  // 记录删掉了几个0for(i = 0; i < nums.size(); i++){if(nums[i] == 0){nums.erase(nums.begin()+i);n++;i--;    // 删掉当前元素,数组会立即发生变化!}}// 删了几个元素,后面补几个0        for(i = 0; i < n; i++){nums.push_back(0);}}
};

运行结果:

好吧,看了一下官方双指针代码,它的效果要好一点。。

class Solution {
public:void moveZeroes(vector<int>& nums) {int left = 0, right = 0;int n = nums.size();while(right < n){if(nums[right]){swap(nums[left], nums[right]);left++;}right++;}}
};

 它的思路:

 

 

 

http://www.15wanjia.com/news/57146.html

相关文章:

  • 淘特app官方网站下载竞价推广哪里开户
  • 福州专业建站公司短链接生成网址
  • 佛山做网站上海好的seo公司
  • 有想做企业网站建设推广公众号
  • 东莞视频网站制作今日军事新闻头条视频
  • 刷赞网站推广软件网站维护工程师
  • 1核2g 做网站seo排名哪家正规
  • 网站功能报价明细表最近国内新闻
  • 并提示网站菜单导航及用户登录互联网站
  • 友点企业网站管理系统模板seo排名需要多少钱
  • 卖辅助网站怎么做的百度seo排名如何提升
  • b2b平台查询seo快速整站上排名教程
  • 自己做网站要买服务器信息流广告投放流程
  • wordpress 购物网站主题seo网站优化培训厂家报价
  • dw网站首页制作大连网络推广公司哪家好
  • 怎样在美国做网站热门关键词排名查询
  • 网站的ftp账号和密码是什么南宁seo网络优化公司
  • 公司网站文章的排版建站模板哪个好
  • 移动办公型网站开发1688黄页大全进口
  • 2022年互联网创业项目关键词优化的策略
  • 给企业建设网站的流程图百度推广怎么收费标准
  • 微信网站开发语言网络营销公司热线电话
  • 网站制作 福宁网络有限公司百度打广告多少钱
  • 上海 房地产网站建设网站排名优化需要多久
  • 上海网站建设 paiky优化法治化营商环境
  • 企业网站建设算什么费用网站引流推广
  • 可以做招商的网站我要软文网
  • 买完域名怎么创建网站怎么制作网站平台
  • 无锡网站定制四川自助seo建站
  • 女生做网站编辑百度地图导航