エンジニアとしての市場価値を測りませんか?PR

企業からあなたに合ったオリジナルのスカウトを受け取って、市場価値を測りましょう

0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Leetcode #27. Remove Element

Last updated at Posted at 2023-06-03

Problem

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.

この問題は、指定された値と等しくない要素のみを持つように配列を変更し、そのような要素の数を返すことを求めています。
InputとOutputの例は次になります。

Input: nums = [0,1,2,2,3,0,4,2], val = 2
Output: 5, nums = [0,1,4,0,3,_,_,_]

Outputのnums配列については、最初の5つの要素が正しければ何でもよく、順番も関係ありません。そのため、[0,0,1,3,4]としたり[0,1,4,0,3,X,X,X]としてもpassします。

Trickyな点としては、配列操作をin-placeに実行するという制約です。つまり、既存の配列のみを使い、追加の配列を作成してはいけないということです。
https://leetcode.com/problems/remove-element/description/

Key Idea

配列を2つのポインタを使います。
1つ目のポインタは、fast-runnerとして、配列を走査するために利用します。

In placeにnumsというリストを変更するため、
Outputとして、numsというリストをin-placeに操作して、左からk個の要素全てがvalではないように並び替える必要があります。
ここで「どこまで並び替えたか」を管理するのに2つ目のポインタを使います。(slow-runner)
言い換えると、このポインタより左の要素は、全てvalではない値で統一されているという仕切りになります。

簡単に手順を書くと下記のようになります。ここではfast-runnerをreader, slow-runnderをwriterという名称にしています。

Approach 1

上記のアイデアは、下記の様にかけます。

class Solution:
    def removeElement(self, nums: List[int], val: int) -> int:
        k = 0 
        writer = 0
        for reader in range(len(nums)):
            if nums[reader] != val:
                nums[writer] = nums[reader]
                k += 1
                writer += 1

        return k

ここで、kとwriterは実質同じ挙動になっていることがわかります。そのため、writerというポインタをなくして、kを活用することができます。

Approach 1'

kとwriterという2つの変数が冗長であるため、一つにまとめることができます。

class Solution:
    def removeElement(self, nums: List[int], val: int) -> int:
        k = 0 
        for reader in range(len(nums)):
            if nums[reader] != val:
                nums[k] = nums[reader]
                k += 1

        return k

計算量は下記の様になります。

  1. Time Complexity: O(n)

ここで、nは配列numsの要素数です。これは、アルゴリズムが配列の各要素を一度だけ走査するためです。

  1. Space Complexity: O(1)
    入力のサイズに関わらず、使用するメモリ量は一定です。

Reference

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?