27
8

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.

競技プログラミングAdvent Calendar 2022

Day 8

競プロ初心者がLeetCodeを150日間継続した話

Last updated at Posted at 2022-12-07

LeetCodeを始めたきっかけ

7月ころにふとLeetCodeに関する記事を読みました。
そこにはGoogleなど大手ではLeetCodeによるコーディング面接が行われていると書かれていました。

そこで、ちらっとアカウントを作成して挑戦してみました。HARD問題に挑戦してみたのですが、あえなく撃沈しました。ここで闘争本能に火が付きました

スペック

普通のITエンジニアです。バックエンドもフロントもインフラもだいたいやってます。プログラミングは苦手ではないですが、競プロは避けて生きてきました。アルゴリズムは一通り授業で学んだレベルです。

LeetCodeとは

LeetCodeは他の競プロサービスと同じように週次・隔週コンテストが開催されています。それとは別に毎日一問課題が出され、継続すると商品と交換ができるコインが貰えたり称号(バッジ)がもらえたりします。
個人的な印象としてはAtCoderなどのガチ系よりもライトなイメージがあり、初心者でも入りやすい気がします(あくまで個人的な印象ですが)。
問題はこのような感じで出題されます(日本語はありません!)
image.png

継続のためのモチベーション維持

LeetCodeには継続を感化する仕組みが備わっています。

1. 草が生やせる

image.png
マイページで画像のように草がはやせるようになっています。継続日数も記録として残るため、継続しようという気にさせてくれます。

2. 1日1問課題が出される

image.png
LeetCodeでは一日一問、過去のコンテストの問題が課題として出題されます。その問題をクリアすると画像のようなチェックマークが付きます。一ヶ月フルコンプリートするとバッジがもらえます。バッジをもらうと嬉しくなりますよね。

ちなみに、課題や草の1日の切り替わりはUTCの0時というのも日本在住ではメリットだったりします。その日の問題が解けずに苦しんだとしても、朝9時まで徹プロできます。

3. 個人的なモチベーション維持

ツイッターで以下のようなツイートをし、毎日このツイートにぶら下げて問題の答えを貼り付けていっています。フォロワーの前で恥をかけないという気持ちも増すため継続する意欲が維持されます。

150日継続して身についたこと

自信

継続して一番身についたのは自信です。今まで競プロを避けてエンジニアをしていたのですが、周りに競プロガチ勢がいたこともありプログラミングへの自信を持てずにいました。継続してみてある程度競プロというものを理解でき、自分のコーディングにも自信を持てるようになりました。

アルゴリズム

競プロの世界に踏み入れなければ知る由もなかったアルゴリズムをたくさん身につけることができました。
セグメント木Trie木Union FindMonotonic Stackなどなど、いろいろなアルゴリズムを身につけることができました。私の本業でアルゴリズムを使う可能性はかなり低いですが、いざとなったときの引き出しとして持っておくことに損はないと思います。

計算量

計算量はとにかく気をつけるようになります。
Listの追加・削除のオーダー、探索のオーダーなどなど

Javaの標準コレクション型

私はKotlinで問題を解いているのですが、Javaのコレクション型で知らないものがいくつかあったりしてその勉強にもなりました
PriorityQueueArrayDequeTreeSet(TreeMap)などは使ったことがなかったのですが、便利すぎて本業でも使うことがありそうな気配があります。

プログラミング言語そのもの!

私は以前からKotlinが一番好きな言語だったのですが、LeetCodeでKotlinを使ってみるとまだまだ知らない事がたくさんあったことに気付かされました。プログラミング言語を極める際も競プロは役に立ちました。

ちなみに、以前私が新入社員の研修で軽く競プロの問題を解く勉強会があったのですが、その際はScalaを使って解きました。その時の私はScalaほぼ初心者だったのですが、課題を解くことを通じてScalaを深く知る機会となりました。
このように競プロは新しいプログラミング言語を学ぶ際にももってこいのコンテンツだと思っています(※なお私は一時期Rustで解いていたのですが挫折してしまいました)

解く速度の向上

最初のほうが1問解くのに1~3時間かかることもあり、かなり大変な思いをしていました。
現在では早くて3分、難しい問題でも1時間くらいあれば解くことが出来るようになりました。

英語力

LeetCodeは英語or中国語専用のため、基本的には英語を読むことになります。この150日で英語力が向上した気がします。おそらく。

解いてると脳をかなり使うので頭が良くなった気がします

慣れてきたらコンテストにも挑戦してみる

LeetCodeにある程度慣れてきたらコンテストに挑戦してみるのもおすすめです。

  • Weekly Contest(毎週 日曜日11:30-13:00)
  • Biweekly Contest(隔週 土曜日23:30-25:00)
    の2種類があります。コンテスト参加者は半数以上が中国人で、その他世界中の人々が参加しています。日本人は3%くらいと言ったところでしょうか。

実際コンテストに参加してみると、自分の劣等感にさいなまれることになると思います。しかし、継続してコンテストに参加していると順位がどんどん上がっていって成長を実感できると思います。
私も4ヶ月ほど前の初挑戦のコンテストでは8000位(20000位中)とかを取ったりしていましたが、現在では最高570位くらいを記録するようになり、成長を数字で実感できます。

おわりに

LeetCodeは、私の良い習慣として継続できているのでこれからも続けていきたいと思っています。
みなさんも1時間だけLeetCodeに時間を割いてアカウントを作成、問題を解いてみてはいかがでしょうか?きっとハマると思いますよ。

image.png

27
8
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
27
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?