LeetcCode 27:移除元素 Remove Element(python、java)
公众号:爱写bug
给定一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。
Given an array nums and a value val, remove all instances of that value in-place and return the new length.
Do not allocate extra space for another array, you must do this by modifying the input array in-place with O(1) extra memory.
The order of elements can be changed. It doesn't matter what you leave beyond the new length.
示例 1:
给定 nums = [3,2,2,3], val = 3, 函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。 你不需要考虑数组中超出新长度后面的元素。
示例 2:
给定 nums = [0,1,2,2,3,0,4,2], val = 2, 函数应该返回新的长度 5, 并且 nums 中的前五个元素为 0, 1, 3, 0, 4。 注意这五个元素可为任意顺序。 你不需要考虑数组中超出新长度后面的元素。
说明:
为什么返回数值是整数,但输出的答案是数组呢?
请注意,输入数组是以“引用”方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。
你可以想象内部操作如下:
Confused why the returned value is an integer but your answer is an array?
Note that the input array is passed in by reference, which means modification to the input array will be known to the caller as well.
Internally you can think of this:
// nums 是以“引用”方式传递的。也就是说,不对实参作任何拷贝 int len = removeElement(nums, val); // 在函数里修改输入数组对于调用者是可见的。 // 根据你的函数返回的长度, 它会打印出数组中该长度范围内的所有元素。 for (int i = 0; i < len; i++) { print(nums[i]); }
解题思路:
只允许原数组修改,可以用双指针,左指针 i 自左向右,右指针 j 从右向左。如果索引 i 和 val 相等,则索引 i 得到索引 j 的值,并且 j 前移一位。如果不相等,i 后移一位。
因为要求是返回修改后的长度并只考虑该长度的数组,那么就不用考虑该长度之后的数组,所以只需得到索引 j 的值,不用再把索引 j 的值改为索引 i的值。
Java:
class Solution { public int removeElement(int[] nums, int val) { int i=0,j=nums.length-1;//i-左指针;j-右指针 while (i<=j){ if(nums[i]==val){ nums[i]=nums[j];//得到索引j的值,无需把索引j的值改为索引i的值 j--; }else i++; } return j+1; } }
Python3:
class Solution: def removeElement(self, nums: List[int], val: int) -> int: i=0 j=len(nums)-1 while i<=j: if(nums[i]==val): nums[i]=nums[j] j-=1 else:i+=1 return j+1
总结:
这道题本身很简单,只要搞清思路,一起都会变得明了。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
为什么那么多人用GO?GO语言的优势在哪里?
Go语言最早并不是一个Google的正式项目,而是作为一个“20%”的项目出现。直到2009年,它被设计成一种系统编程语言,用于具有Web服务器、存储集群或类似用途的大型中央服务器的系统编程语言,目前Go Team有稳定的发布周期,大约半年一个新的版本,目前最新为1.9版本。 对于高性能的分布式系统,GO语言无疑比大多数其他语言更高效。它提供了大量的并行支持,这对于游戏服务端的开发而言是再好不过了。 传统的语言如C++,大家花费太多时间来学习如何使用这门语言,而不是如何更好的表达写作者的思想,同时编译花费的时间实在太长,对于编写-编译-运行这个链条来说周期太长。动态语言如Python,由于没有强类型的约束,很多问题需要在运行时发现,这种低级错误更应该交给编译器来发现。 在人力成本越来越高、机器越来越便宜、机器的性能越来越厉害、想要在开发效率和运行速度上达到平衡的趋势趋势下,Go语言诞生了。 我们先来对比一下go语言与其它开源语言比较具有哪些优势? 与C++比,go的开发效率高,具有清晰的依赖管理和全自动垃圾回收机制,代码量大幅减少。 与Java比,更简明的类型系统。 与php比,go在...
- 下一篇
Spring Framework 组件注册 之 @Component
Spring Framework 组件注册 之 @Component 写在前面 在spring大行其道的今天,对于spring的使用和掌握乃是不可缺少的必备技能。但是spring的整个体系尤为庞大,对它的学习,还得从基础一点一滴的慢慢积累。本文主要介绍@Component注解在spring中的简单使用,以及注解的派生性和层次性 @Component 简单使用 @Component注解是一个元注解,即可以标注在其它的注解上。在spring中,任何被@Component注解标识的组件均为组件扫描的候选对象,并且被@Component元注解标注的注解,在任何组件标注它时,也被视作组件扫描的候选对象。简单来说,就是在spring中,一个普通的javaBean被@Component注解标记后,在使用基于注解配置和类路径扫描时,会被作为候选组件,添加到spring容器中 package com.spring.study.ioc.register; /** * spring扫描的候选组件 * * @author TangFD * @since 2019/6/25. */ @Data @Compone...
相关文章
文章评论
共有0条评论来说两句吧...