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

株洲县建设局官方网站郑州惠济区建设局网站

株洲县建设局官方网站,郑州惠济区建设局网站,做流量的网站,店铺在百度免费定位《算法通关村——双指针妙用》 删除元素 描述 给你一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,并返回移除后数组的新长度。要求:不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并原地修改输入数组…

《算法通关村——双指针妙用》

删除元素

描述

给你一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,并返回移除后数组的新长度。要求:不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并原地修改输入数组。元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

例子1: 输入:nums = [3,2,2,3], val = 3 
输出:2, nums = [2,2] 
例子2: 输入:nums = [0,1,2,2,3,0,4,2], val = 2 
输出:5, nums = [0,1,4,0,3]

三种解决方法解决

/*** 删除指定元素用快慢指针,慢指针用于填充不删除的值,快指针用于查找目标值* @param nums* @param val* @return*/
public static  int removeElement(int[] nums,int val){int slow = 0;// fast充当快指针for(int fast = 0;fast<nums.length;fast++){if(nums[fast] != val){nums[slow] = nums[fast];slow++;}}return slow;
}/*** 对撞指针的方法,两个指针从两边走,左边如果不相等(不等于目标值)就往后,right等于目标值就往前。* @param nums* @param val* @return*/
public static int removeElement1(int[] nums,int val){int right = nums.length-1;int left = 0;while(left <= right){if((nums[left]==val) && (nums[right]!= val)){int temp = nums[right];nums[right] = nums[left];nums[left] = temp;}if(nums[left] != val)  left++;if(nums[right]==val) right--;}return left;
}/*** 双指针+覆盖,这种就是直接覆盖了,如果从左开始有值等于目标值,就把他替换成从右边开始的值,然后右边指针移动,左边不动,* 然后再次判断左边原位置是否是目标值,如果是就继续覆盖,右边指针继续移动,如果不是左边指针移动。* @param nums* @param val* @return*/
public static int removeElement2(int[] nums, int val){int right = nums.length - 1;for(int left = 0; left<=right;){if(nums[left] == val){nums[left] = nums[right];right--;}else{left++;}}return right+1;
}

删除重复项

描述

给你一个有序数组 nums ,请你原地删除重复出现的元素,使每个元素只出现一次 ,返回删除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组 并在使用 O(1) 额外空间的条件下完成。

示例1: 
输入:nums = [1,1,2] 
输出:2, nums = [1,2] 
解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。  
例子2: 
输入:nums = [0,0,1,1,1,2,2,3,3,4] 
输出:5, nums = [0,1,2,3,4] 
解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。

解决

/*** 删除数组中重复元素,返回数组的大小。慢指针进行存值覆盖,快指针判断是否为重复值。* @param nums* @return*/
public static int removeDuplicates(int[] nums){// slow表示可以放入新元素位置,索引为0的元素不用管.int slow = 1;// 循环起到了快指针的作用for(int fast = 0;fast < nums.length;fast++){if(nums[fast] != nums[slow-1]){nums[slow] = nums[fast];slow++;}}return slow;
}

近期在自学 Java 做项目,加入了一个编程学习圈子,里面有编程学习路线和原创的项目教程,感觉非常不错。还可以 1 对 1 和大厂嘉宾交流答疑,也希望能对大家有帮助,扫 ⬇️ 二维码即可加入。

在这里插入图片描述

也可以点击链接:我正在「编程导航」和朋友们讨论有趣的话题,你⼀起来吧?

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

相关文章:

  • 手机网站设计软件什么是h5页面设计
  • 沧州网站建设公司翼马忻州网络公司网站建设
  • 怎么做网站的301给蛋糕店做企业网站的文案
  • 青海省建设银行网站公司黄页是指什么意思
  • 公司网站推广执行方案机电设备网站模板
  • 品牌设计logo图片浙江seo技术培训
  • 企业网站设计百度推广账号怎么申请
  • 潞城市网站建设公司网站开发高级工程师专业
  • 服务行业网站建设英文网站 字体大小
  • 做有关兼职网站的需求分析网站的设计风格有哪些
  • 2018年做返利网站盘锦网站建设
  • 曲周企业做网站推广贸易网站建设公司
  • 网站百度不收录广告文案策划
  • 网站上线后网站建设与管理办法
  • 北京公司网站怎么制作开发者社区
  • 广州网站手机建设公司简单个人网站制作
  • 凡科网站建站后 怎么编辑自己的代码源整站优化该怎么做
  • 做有后台的网站仿牌网站服务器
  • 合肥哪家做网站大街网企业招聘官网
  • 网站开发图标安徽省建设工程信息网安徽省政务
  • 自己做的网站找不到了0453牡丹江信息网手机极速版
  • 网站维护工程师工资网站建设开发实训的目的
  • 建设网站是哪个部门负责企业网站建设开发服务
  • 网站加入购物车的代码禾天姿网站建设
  • 那个网站有用director做的片头自助建站最大
  • 怎么做网站数据库备份现在去成都安全吗
  • 阜新网站建设梅河口市住房和城乡建设局网站
  • 网站开发 附加协议东莞阳光网英语口语大赛官网
  • 网站meta 优化建议怎样免费做自己的网站
  • 邹城网站定制营销型网站建设公司哪家建设营