0027 - Remove Element (Easy)
Problem Link
https://leetcode.com/problems/remove-element/
Problem Statement
Given an integer array nums
and an integer val
, remove all occurrences of val
in nums
in-place. The order of the elements may be changed. Then return the number of elements in nums
which are not equal to val
.
Consider the number of elements in nums
which are not equal to val
be k
, to get accepted, you need to do the following things:
- Change the array
nums
such that the firstk
elements of nums contain the elements which are not equal toval
. The remaining elements ofnums
are not important as well as the size ofnums
. - Return
k
.
Custom Judge:
The judge will test your solution with the following code:
int[] nums = [...]; // Input array
int val = ...; // Value to remove
int[] expectedNums = [...]; // The expected answer with correct length.
// It is sorted with no values equaling val.
int k = removeElement(nums, val); // Calls your implementation
assert k == expectedNums.length;
sort(nums, 0, k); // Sort the first k elements of nums
for (int i = 0; i < actualLength; i++) {
assert nums[i] == expectedNums[i];
}
If all assertions pass, then your solution will be accepted.
Example 1:
Input: nums = [3,2,2,3], val = 3
Output: 2, nums = [2,2,_,_]
Explanation: Your function should return k = 2, with the first two elements of nums being 2.
It does not matter what you leave beyond the returned k (hence they are underscores).
Example 2:
Input: nums = [0,1,2,2,3,0,4,2], val = 2
Output: 5, nums = [0,1,4,0,3,_,_,_]
Explanation: Your function should return k = 5, with the first five elements of nums containing 0, 0, 1, 3, and 4.
Note that the five elements can be returned in any order.
It does not matter what you leave beyond the returned k (hence they are underscores).
Constraints:
0 <= nums.length <= 100
0 <= nums[i] <= 50
0 <= val <= 100
Approach 1: Two Pointers
We can use two pointers, one to iterate through the array, and one to track the size of the final array. When we run into a number that belongs in our array, we can just move it to our position, and update k. That means numbers that equal , won't get moved, and will eventually get overwritten, and we can in the end return .
Time Complexity: , where is the length of . We must iterate every number in nums to get our solution.
Space Complexity: , we will do all our work in place, using pointers.
- Python
class Solution:
def removeElement(self, nums: List[int], val: int) -> int:
# initialize our k value, which will be the length of our final array.
k = 0
# iterate numbers
for i in range(len(nums)):
# if nums != val, and belongs inside our final array.
if nums[i] != val:
# move that num to the kth position and increment k.
nums[k] = nums[i]
k += 1
# return k, which will be all nums from 0-k, non inclusive of k.
return k