Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
LeetCode 83 - Remove duplicates from sorted list
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Kohei
March 21, 2020
Programming
420
2
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
LeetCode 83 - Remove duplicates from sorted list
Kohei
March 21, 2020
More Decks by Kohei
See All by Kohei
LeetCodeガイド
1kohei1
2
950
UCF Fall 2017 Senior Design final presentation
1kohei1
0
68
アメリカでの一年目
1kohei1
0
94
Other Decks in Programming
See All in Programming
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
3
2.2k
[2026年度第1回ORセミナー] 計画最適化ベンチャーと競技プログラミング人材
terryu16
0
270
並列実装の現場、2ヶ月間実務でAIを使い倒したAIもPCも私も限界が近い
ming_ayami
0
130
ADKを使って簡単にAIエージェントを作ってみよう
k1mu21
0
270
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
21
6.8k
TAKTでAI駆動開発の品質を設計する
j5ik2o
7
1.4k
Snowflake Summitでの新機能 CoCo / CoWork / snowflake-summit-2026-overall-what-new-coco
tatsuhiro
1
160
代数的データ型って何が嬉しいの? #frontend_phpcon_do
kajitack
8
3.7k
TSKaigi Night Talks 2026_TypeScriptでサプライチェーンの整合性を型に閉じ込める
geekplus_tech
0
400
dRuby over BLE
makicamel
2
380
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
550
スマートグラスで並列バイブコーディング
hyshu
0
240
Featured
See All Featured
Everyday Curiosity
cassininazir
0
230
The World Runs on Bad Software
bkeepers
PRO
72
12k
How to Ace a Technical Interview
jacobian
281
24k
Making Projects Easy
brettharned
120
6.7k
Paper Plane (Part 1)
katiecoart
PRO
0
9.1k
Optimising Largest Contentful Paint
csswizardry
37
3.7k
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.3k
The Spectacular Lies of Maps
axbom
PRO
1
820
4 Signs Your Business is Dying
shpigford
187
22k
Statistics for Hackers
jakevdp
799
230k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
200
How to Grow Your eCommerce with AI & Automation
katarinadahlin
PRO
1
210
Transcript
Remove duplicates from sorted list LinkedListから重複した要素を削除する
内容 • 例を使って問題の確認 • 考えられるコーナーケース • 面接官に確認するべきこと • 解法 •
解法コード (Java) • LeetCodeの解法を解説
例を使って問題の確認 重複が含まれる、すでにソートされた LinkedListが渡されます。
例を使って問題の確認 重複が含まれる、すでにソートされた LinkedListが渡されます。 渡されたLinkedListから重複した値を持 つノードを削除したLinkedListを返しま す。 この例の場合、1が重複しているのでその 余分なノードを削除します。
考えられるコーナーケース ノードが1つの場合
考えられるコーナーケース ノードが1つの場合 全て同じ値の場合
考えられるコーナーケース ノードが1つの場合 全て同じ値の場合 ループがある場合 (ソートされ てるとは言えないので、わたさ れないはずです)
考えられるコーナーケース ノードが1つの場合 全て同じ値の場合 ループがある場合 (ソートされ てるとは言えないので、わたさ れないはずです) nullの場合
面接官に確認するべきこと • 与えられるLinkedListにループは含まれるか • 与えられたLinkedListを変更してもいいのか、それとも新しいLinkedListを返すべき か • LinkedListの値を比べる際、==で比べてもいいのか、それとも別の方法で重複を確 認するべきか 面接では意図的に条件をあやふやにしていることが多いです。曖昧な問題にどうアプ
ローチするかを見ています。前提条件や求められる出力を確認して、その力があること を示しましょう。
その1: すべての要素を保存し、ソートして新しいLinkedListを作る => 計算量: O(N logN), 空間計算量: O(N) その2: ソート済み・重複なしの要素を保存し、新しいLinkedListを作る
=> 計算量: O(N), 空間計算量: O(N) その3: 与えられたLinkedListをそのまま変更していく => 計算量: O(N), 空間計算量: O(1) 解法
その1: すべての要素を保存し、ソートして新しいLinkedListを作る => 計算量: O(N logN), 空間計算量: O(N) その2: ソート済み・重複なしの要素を保存し、新しいLinkedListを作る
=> 計算量: O(N), 空間計算量: O(N) その3: 与えられたLinkedListをそのまま変更していく => 計算量: O(N), 空間計算量: O(1) 計算量、空間計算量で優れているその3を実装します 解法
与えられたLinkedListをそのまま変更していく => LinkedListを順番に見ていき、今までみた最大値を持つノードをキープします。最大 ノードと違う値がきたら、それが次のノードになるようにnextの値をアップデートします。 下のLinkedListを使います。 解法
今まで見たなかでの最大値ノードをmax, 今見ているノードをcurrとします。 最初はどちらも1番目のノードです。 解法
maxはそのままで、currが次のノードへ移動します。maxとcurrの値が同じなので何も起 きません。 解法
currが次のノードへ移動します。 解法
maxとcurrの値が違うのでmaxのポインタがアップデートされます。これで重複していた2 番目の1が、LinkedListから消えました。 2番目の1のポインタは変わってませんが、LinkedListの中に含まれないので問題ありま せん。 解法
最大値が2になったので、maxをアップデートします。 解法
currが次のノードへ移動します。 解法
maxとcurrの値が違うのでmaxのポインタがアップデートされます。ただ、この例ではアッ プデートされても変化がありません。 解法
最大値が3になったので、maxをアップデートします。 解法
currが次のノードへ移動します。nullとなり、LinkedListにある全ての要素を見終えまし た。 解法
最後にmax.nextをnullにします。なぜなら、maxが最後のノードになるからです。この例 では変化がありませんでした。 解法
最後にmax.nextをnullにします。なぜなら、maxが最後のノードになるからです。この例 では変化がありませんでした。 このステップが必要なのはmaxと同じ値のノードが続き、currが終わったときにmax.next がアップデートされないからです。下のLinkedListがそのケースです。 解法
解法 プログラムが終了すると、重複された要素がLinkedListから消えてるので、無事要件を 満たしました。
解法コード これをコードにすると右のようなコードになります。 https://harigami.jp/cmp_rs?hsh=c22f22fe-c8a6-44d5-802f-5baeaf666697 次にLeetCodeの解法についてです。 よりきれいな実装で問題を解いてます。
LeetCodeの解法を解説 https://leetcode.com/problems/remove-duplicates-from-sorted-list/solution/ currentとcurrent.nextが同じ値の場合、current.nextをスキップすることで、currentと同 じ値のノードをスキップし続ける実装になっています。 nullの場合分けもなく、whileループが終わったら全ての重複が取り除かれているため、 非常にきれいな実装です。
Thank you 作者: @koheiarai94