コードレビューを試す会
binnmti
始まってますね。
実は趣旨を説明しようかなと 思いますけど、
みんなでコードレビューを試す会 というタイトルにして、
自分が他の人と喋っている時に、 コードレビューをする機会が
あんまりないみたいな話を聞いて、 コードレビューって結構僕は
僕はプログラマーにおいては、 ものすごいデカい機能というか、
すごいものができたなって思ってて、 コードレビューができる前とできた後で、
コードに対する安定性とかって、 段違いになったんじゃないかなと
思ってたんで、ぜひもっといろんな人が コードレビューみたいなことを
体験できる機会があればいいなと思って、 これを企画しました。
ただ、コードレビューをするには 当然なんですけど、コードが必要で、
なかなかこのスタイルでコードを 持ってきてくださいっていうのは
ちょっとレベルが高いなと思ってたんで、 どういう形でやれば
勉強会の提案を出せるかなって思った時に、 アルゴリズムを解くっていうのは
結構いいかもしれないって思いました。
アルゴリズムを解くっていうのは 一問に特化できるし、
その中でどれコードを解くかみたいなことを 考えるだけでも面白いと思うので、
今日結構計算業の話とか、 どうやって解くかみたいな話も含めて
いろいろ説明していこうかなって 思っているので、
コードレビューをしつつ、 アルゴリズム問題を解きつつ、
そこから派生式ACシャープのいろんな話を する可能性もあるんですけど、
それらが一番僕が重要かなと思っているのは 楽しめるかなって思っていることなので、
そんな難しそうな回って思ってもらうよりは、
すごいコードをかけて楽しかったですって 言ってもらえるのが一番嬉しいと思うし、
こんな質問とかしてもいいのかな みたいなことは全然考えずに、
全然いつでも止めてもらって、 何でも聞いてもらえばいいかなと思っているので、
そんな形でワイワイガヤガヤ進めれるのが 理想だと思っています。
一応今回資料を作っていくので、 その資料からやろうと思うんですけど、
さっき雑談でちょっとしゃべってましたけど、
今回はマークダウンで資料が作れるっていう、
スライデブっていうサービスがあったので、 それで資料を作ってみました。
実際こういう感じでマークダウンで わーって書いて、
NPMでビルドするとそれが資料になって、 こんな感じで資料ができますと。
コードとかも書けるので、
実際パワポでコードとか貼り付けるのって、 意外と思った通りにできなかったりするので、
そういうところにデータを書けるのって 意外とアホらしいなと思うんですけど、
マークダウンだとフォーマットがしっかりしてるので、
それの通りに書いてそれをそのまま資料にしてくれて、
これGitHubで管理しておけば、
GitHubページにそのまま上げることもできるので、
Ippei Usami
これもう今そのまま実は上がってるんですけど、
これかな?
binnmti
これ僕のGitHubのアカウントなんですけど、
さっきのこの資料はGitHubって 一応アカウント作ってるやつでやってるので、
Ippei Usami
全く同じものが世界で見える形になってる状態です。
binnmti
一応資料の感じで進めていくと、
一応ローカルのほうでやってるやつで、
自己紹介は別にみんな知ってるのでいいかなと思います。
今回はリートコードっていうのを使って 進めていこうかなと思うんですけど、
リートコード知ってる方はいらっしゃいます?
初めて知りました。
一応コンパスのほうには書いてあったと思うんですけど、
今回もうできればアカウントまで作ってもらおう。
この場でアカウント作ってもらって そこで解くのがいいかなって思ってるんですけど、
まず最初に謝罪があって、
ごめんなさい、一問目を解くっていう趣旨にしたんですけど、
資料作ってて説明するのに若干ちょっと やりづらいところがあったんで、
ほとんど一緒なんですけど、
Ippei Usami
問題を変えたいと思います。
binnmti
今リートコードに行ってもらって、
160ならば同じ2,3っていう問題があるので、
リートコードアカウント今作れます?
今ちょっとロゴンしようとしてる。
アカウント作らないといいのですか?
Ippei Usami
アカウント作らなくても問題を見ることはできます。
binnmti
で、できないのは解くことができない。
Ippei Usami
そうなんですかね。
binnmti
サブミットできない。
そうですね。
ラントサブミットができないので、
この後ローカルでやる方法も 説明しようかなと思ってるんですけど、
最終的にはここでテストが見えるんですけど、
3個こうやってテストが見えるんですよね。
これで走らせることもできるんですけど、
実はこのテストリザルトやると、
もっと何百枚もチェックが走る状態になって、
アルゴリズム問題と解法の説明
binnmti
全部クリアできるかどうかっていうのが分かるので、
ここ上でコード書くことももちろんできるので、
何も使わなくても問題を解いていくことはできるんですけど、
Ippei Usami
実はこれインテリセンスも効かないんですよね。
効かないわけじゃなくて、有料です。
binnmti
お金払うとできたりするんですけど、
ここにオートってあって、
ログインしても使えなかったので、
ローカルで使った方がやりやすいかなと思ってるので、
今回はこの167番を解いていくっていう感じで、
進めていこうかなって思ってます。
Ippei Usami
今私の状態は、
リードコードのページまでたどり着こうとしてて、
くるくる回ってる状態。
あ、ネットワークが重い。
binnmti
ここのゲストのネットワーク?
一応ネットワークはLTEで持ってたので、
Ippei Usami
大丈夫ですか?
ここの使ってもらっても?
Wi-Fiはちょっとどうかなと思ってたので。
binnmti
もしあれだったら、
ここのWi-Fi使います?
Ippei Usami
使わせてもらっていいですか?
ネットワークになったら大丈夫かな?
どうするかな?
binnmti
あと、GitHubにリポジトリまで作っちゃってもいいかなって、
個人的には思ってます。
ミスではないんですか?
後ろに入ってます。
Ippei Usami
これはSSH?
SSHです。
アジアカスタードがちょっと長いんですけど。
すいません、すいませんですね。
そっちもカウント用意してみると。
binnmti
これは事前にやっといてもよかった。
そんなに慌てなくても、
Ippei Usami
来てもらってからやるでもいいかなって思ってたので。
これいいかな?
3、2、1。
打ち間違えられるのかな?
binnmti
今日、白石さんとも話してたんですけど、
アルゴリズム問題って、正直答えを探せば、
わりと世の中に転がってるし、
このリート構造上でも、実はディスカッションみたいなのをしてて、
そこを見ると答えはだいたいわかるんですよね。
このソリューションズというところで
みんなが回答について喋っていたりするので
答えが知りたい人は
いくらでも探る術はあります
ただアルゴリズム問題は
できれば自分で1回解いてから
他の人の答えを見る方がいいと思うので
そこは正前説みたいな話にしかならないですけど
いきなり答え見て解くだとやっぱり
あんまり学習効果が薄いかなと思うので
ぜひ悩んだせいで解けなかったというのは
全然アリだと思うんですけど
考えた状態で答えを見るのと
全く何もせずにいきなり答えを見るのでは
全く学習効果が違うかなと思うので
ぜひ事前に解いてくるにしても
時間をかけて考えた上で
答えを見るようにした方がいいかなと思っています
全く同じ理由で
GitHubコパイロットとか入ってらっしゃる人も
結構いるかなって思うんですけど
割とアルゴリズム問題は
的確に答えをすぐ提案してくるケースが多い
っていう印象を僕は強く持っています
やっぱりGenerative AI全般的に
答えが明確な問題っていうのは
強いかなってすごく思っているので
実際よくあるケースとして
普段だったらメソッド作っただけで
もう大体の答えの提案してくるときもあるんですけど
それをしないにしても
ifって書いたら割と次々と提案してくれて
自分としては学習の効果もあると思うので
考えたいと思っているのに
いきなり答えのコードをバッて出されたりすると
いやいやまだ考えてるんだけどって
思ったりすることがあるので
もしかしたらアルゴリズム問題を解くときは
これはいいと思ってますけど
コパイロットは切っといたほうが
あまり答えをいきなりやらずにする
っていう面あると思うので
そこは各自にお任せしますけど
答えはあまりないとか
コパイロットは使わないほうが
いいかなって思ってます
サイトに関して言うと
ヒントがある問題とかも結構あったりするので
リートコードの利用とGitHubにリポジトリの作成
binnmti
どうしても悩んで分かんないときとかは
それを見たりするでもいいかなって思ってます
この辺は本当に任意の話にしかならないと思うので
推奨としては先に答えを知っておくのは
あまり良くないんじゃないかなっていうぐらいで
Ippei Usami
考えてください
binnmti
アカウント作ってました
では一問目を解くところからやろうかなと
思ってるんですけど
167に入るためにどこに
プロフレームリストっていうのがあって
あるいは検索してもいい
Ippei Usami
ビートボード167で検索すれば
binnmti
それが一番早いかもしれない
Ippei Usami
Googleで検索したら
Googleで検索したら
binnmti
それがたぶん
167のビートボードね
Ippei Usami
これも日本語翻訳したらいいかなと思ってるので
binnmti
先にちょっとコードどうやって書くか
説明からしようかなと思うんですけど
さっきも言った通りここでいきなり書いてもいいです
ここで言語を選べるので
日本語にしてるとすごい可能性がある
ここでCシャープにしておいたら
こんな感じで回答が出ますと
でもこれだけだと
さっきも言った通りインテリセンスとか
効かないので
ローカルに
いきなり作っちゃってもいいですし
GitHubでリポジトリ作って
新規で作成するっていう形でも
どっちでもいいかなとは思ってるけど
僕も今回作っていく形にしようかなと思うので
テストプロジェクトをまず作るところから
Ippei Usami
これ自体はまだ作ってるな
もう一個新規で
binnmti
新しいプロジェクトの作成から
これ出た
Ippei Usami
いきなり落ちる
binnmti
Visual Studioが不安定なんですよ
Ippei Usami
って話をさっきしてたんですけど
binnmti
ちょっと落ちますね
新しいプロジェクトで
MSテストを使って
Ippei Usami
1個
binnmti
CSプロジェクトを作ってもらいたいなと思ってて
テストは多分
世の中的には3種類
今メジャーなのがあって
MSテストとXユニットとLユニットがあります
どれを使うかは正直僕はどれでもいいかなと思ってて
若干の癖はありますけど
ある程度わかってきたら
そのまま他に利用できることがほとんどなので
どれを使わなきゃいけないみたいなことは
MSテストを使用した問題解決
binnmti
あんまり気にしなくてもいいかなと思います
調べてたシェア率みたいなことで言うと
今Xユニットが多分一番人気ならしいし
そこはそれぞれ自分の好きなものを
使うぐらいの感じでもいいんですけど
僕はMSテスト使い慣れてるので
MSテストで説明しようかなって思ってます
一応ソリューション作ったっていう前提にして
新規でファイルを作って
Ippei Usami
どれだっけ
新しい項目でいいのかな
これあんま作ったことない
あるやつを利用させてもらおうか
こんな感じで今回は167なんで
167みたいなのをちょっと一個作ります
binnmti
167っていうクラスを一旦作って
全部一体消します
テスト系クラスだけある状態で
ここにあるこのメソッドだけを
Ippei Usami
ローカルに持ってきます
binnmti
こんな感じですかね
テストケースを作って
Ippei Usami
メソッドを作って
binnmti
最初はこんな感じ
テストメソッド1に対して
Ippei Usami
今回の問題が
これが問題なんですけど
binnmti
このナンバーズっていう
イントの配列が渡ってきて
ターゲットっていう数値を持ってますと
この中から2つの数字を取ってきて
このターゲットになる
1番目だと2と7を足せばターゲットになるし
2番目だと1番目と3番目を足せば6になる
っていうターゲットがあるので
それをそのインデックスを
アウトプットとして返してください
という問題です
それをここに同じように書いてみますと
binnmti
そのまま持ってくるとこんな感じ
ナンバーズは2,7,10,1,15
ターゲットは9
エクセプテッドが0と1
これビルドさっき取ってないのはなぜだ
Ippei Usami
この書き方は
binnmti
ちなみにこれC♯の12かな
12からこの書き方ができます
□からこう
古いやつだとこうじゃないと書けないですね
これを最新の書き方で書くとこうなります
Ippei Usami
.NET8を入れてないと多分この書き方できないかも
binnmti
同じように入れたらこういうふうに返せるので
Ippei Usami
こういう形にしますと
binnmti
これでこのQSAMを自分で実装してみましょう
というのが今回の主題というかやり方です
皆さんもうやってきてるんでしたっけ
何だったら
全く同じ問題じゃないんで
QSAMとほとんど同じなんですけど
全く同じではできないので
Ippei Usami
これを今からみんなで15分30分くらいかけてやってみましょうか
binnmti
準備できましたか
Ippei Usami
私今準備できてるのはプロジェクトまで作ったんだけど
テスト環境までちょっと作ってないな
どうとかはなんとなくわからないけど
binnmti
そこにたどり着くかちょっと今自信ない
このテストプロジェクトは今起動してます
Ippei Usami
プロジェクト自体はVisual Studio 2020で作っています
ただちょっとコードを隠した準備ができるかというのを
binnmti
ちょっと今手伝いましょう
手伝いましょうか
ビルド修正のステップ
Ippei Usami
コピったりしたら早いとこだったらすぐ手伝いますけど
binnmti
ちょっと今で終わりますか
Ippei Usami
今回の問題見てて相当されてないと難しいなと
binnmti
思ってたんですけど
Ippei Usami
今ソロトークで書いたんじゃなくてそうかと思って
binnmti
一回ちょっとこれ抜きます
僕もこれスイッチ置きます
Ippei Usami
準備するところからちょっとスタートしてるんで
binnmti
ちょっと待っちゃったのでここで終わります
Ippei Usami
全くお気になさらずに
binnmti
確かにコパイロットも答え言ってきましたね
これで言ってくるんですかもう
言ってきます
Ippei Usami
なんで判別できるの
これ別の問題となんで判別できるの
binnmti
入力値の答えでわかっちゃう
多分入力値と答えでしょうね
Ippei Usami
あげてる人いるでしょうか
binnmti
さらにコパイロットの提案を良くしたかったら
多分この問題をコピってコメントにして貼ると
多分さらに精度が良くなると思います
Ippei Usami
仕様の方を渡そうかな
binnmti
こんな感じにすれば
Ippei Usami
答えが出ちゃう
今私ができた頃は
binnmti
Visual Studio 2020に対して
Ippei Usami
ソフィションの中にCシャープのプロジェクトと
MSテストのプロジェクトを作ったところかな
まずMSテストの
binnmti
これある状態なので
Ippei Usami
コードを持っていきましょうか
binnmti
これが答えを書くべきコードになるので
Ippei Usami
これは元々テスト対象の関数ですよね
binnmti
これぷらぷらですね
Ippei Usami
シャープに書いて
そうでしたね
ついついCシャープ
binnmti
ぷらぷらでやってもいいですけど
Ippei Usami
今回はシャープでやってもらったほうがいい
binnmti
テスト前に書いちゃったんですよ
ユニットテストのところに
Ippei Usami
ユニットテストのところに書いちゃった
じゃあこれがプラスなので
プラスの中に
binnmti
そこに書いちゃって
さっき書いたやつを
資料のリンクを
コンパスかツイッターですけど
ツイッター今フォローしてましたっけ
Ippei Usami
ツイッターなんか使ってないのよ
binnmti
そうですか
Ippei Usami
テストコードだよね
binnmti
このURL今売ってます?
若干めんどくさいけど
Ippei Usami
打つのは何も取れない
URLですか?
はい
binnmti
ちょっと小さいですけど
mti
Ippei Usami
nnmですね
binnmti
mti.github.io
Ippei Usami
これ
これが用意ですね
binnmti
slash
slave
Ippei Usami
sol
ソルブね
binnmti
ソルブ
ごめんなさい
ソルブ
Ippei Usami
ビートコード
ビートコード
ビートコード
binnmti
これでいけるんじゃないですか
これで
Ippei Usami
これピントかな
ちょっと
こっちこびれないのか
失礼
binnmti
ここでこびれれば残った
Ippei Usami
スライドの前についた
なんか映った映った
こびれますね
これを
こびれますね
binnmti
今日テストコードだね
Ippei Usami
はい
テスト
binnmti
こっちだこっちだ
パラメタライズテストの実装
Ippei Usami
そうでしたっけ
テスト
binnmti
ごめんなさい
失礼しました
こっちはね
こっちですね
これね
こっち今戻り値がないんで
Ippei Usami
リターン
binnmti
リターン
Ippei Usami
ビルド通りますね
これ気になるけど
binnmti
そうですね
Ippei Usami
失敗
ビルドが失敗したのは
なんていうか
binnmti
これ.NETいくつですかね
Ippei Usami
.NET7
binnmti
7
ランケージを多分
発信すれば
Ippei Usami
プロパティね
オブジェクトのプロパティね
うーん
binnmti
ランケージどうやってやればいいんだっけ
Ippei Usami
ちょっと待ってくださいね
binnmti
点を設定だけにすれば
確かにいけたはずで
ランケージ
Ippei Usami
発信とか
おそらく
そんなに大した問題じゃないはずなんですけど
それぞれでもいいかもしれない
えっと
binnmti
このCSプロジェ開いて
ここですね
Ippei Usami
ここに
binnmti
このランケージバージョンっていうのを
多分プレビューとかで入れれば
Ippei Usami
こうですね
binnmti
これでいけるはず
Ippei Usami
ちょっと待ってね
ここダブルクリックしたら
binnmti
ダブルクリックした
このヌラブラの後ぐらいに
Ippei Usami
ランケージバージョン
binnmti
ラングバージョンか
Ippei Usami
ラングバージョン
ラングバージョン
でプレビュー
binnmti
これでビルドしたらいかないですかね
Ippei Usami
改めて
binnmti
やっぱり
Ippei Usami
ダメだな
単純な問題だと思う
binnmti
別の問題ってことですか
Ippei Usami
ここに
カッコ
カッコの対応をちゃんと
持ったけれど
なんかなるのではないのかな
あー
あーいいいい
そうか
一個取れないんだよ
まずはこっち
ただちょっとこれが
気になるけど
binnmti
やっぱりこれ
Ippei Usami
言語でダメだっていう
プレビューバージョン
それを
binnmti
ラングバージョン
Ippei Usami
プレビューバージョン
言語バージョンで
binnmti
プレビューで受け入れるはずだな
言語バージョンプレビューって
最初の試写とか
ロックネットのバージョン
言語バージョンで受け入れるはずなので
Ippei Usami
多分配列を返さないと
返せばいいんじゃないかな
じゃあもう
あまり考えずに
binnmti
そうですね
Ippei Usami
これいいのかな
とりあえず
うーん
それでも確かにいいな
9行目って言ってないのか
9行目と
binnmti
20行目か
Ippei Usami
20行目
binnmti
9行目はダメか
Ippei Usami
職種がいる
binnmti
でも赤くなくなった気がする
Ippei Usami
こうですか
試写
これこう言われてるのは
ダメ
binnmti
その書き方じゃダメかも
ニューの
Ippei Usami
イントの
binnmti
0なくして
そうですね
Ippei Usami
これでいいんじゃないかな
Cシャープはなかなか
binnmti
Cシャープはなかなか
Ippei Usami
たくさん使わないと
いろいろ聞かないと
binnmti
でもさっきのはいけましたね
上の
9行目と11行目が
ダメなんで
新車の新しい書き方が
うまくいってないので
Ippei Usami
ニューの
たぶんそれでいけるんじゃないかな
下のやつは
binnmti
先のカッコなくした
イントとカッコなくした
Ippei Usami
カッコいらない
binnmti
その仕方でいけるんじゃないかな
Ippei Usami
上のカッコなくせば
こっちの
これでたぶんいけるんじゃないかな
これもダメ
binnmti
四角カッコやめて
まず空カッコで
そのあとは
Ippei Usami
たぶんこれでいけるんじゃないかな
すみませんね今から
binnmti
いえいえいえ全然お気になさらず
Ippei Usami
準備が
binnmti
OKですね
Ippei Usami
すみません
ドライバー映った
binnmti
まずいったん解ければいいと思っているので
どういう風でもよいです
Ippei Usami
ゴリ押しなら解ける方法は簡単だと思います
binnmti
ゴリ押しなら面白い
他の人も待ちましょう
Ippei Usami
デュートコード通した方がいいですか
binnmti
デュートコード通した方が
今のローカルのやり方だと
テストが一つしか通らないので
そのテストの書き方ですけど
Ippei Usami
さらに
binnmti
もう一段階上げようかなと思っていて
エンドさん一回
このテストメソッド
こうやって書いたじゃないですか
これ3パターンぐらい
もともとのサイトには書いてあったと思うんで
書き方的には2つあって
これを量産する形
もう一個こう書いて
テストメソッドに作って
こっちを書き換えるという方法も
あるんですけど
別のやり方を説明しようかな
と思っていて
この
ナンバーとかターゲットとか
エクセプテットって
テスト1,2,3見てもらえば分かる通り
型が全部決まってるじゃないですか
Ippei Usami
そういうものは
binnmti
パラメタライズテストという方法で
書けるので
こっちで書く方がいいかなと思うので
その書き方を今説明します
Ippei Usami
えっと
binnmti
MSテストの
書き方になりますけど
二重ループによる配列の並べ替え
binnmti
データロードという書き方が
あります
今実際これちょっと見せますけど
こんな感じ
要は
性的に決まってるものに関しては
ここに
羅列して書くことができるので
今実際ナンバーってこんな感じなんで
ターゲットが9
エクセプトが01なんで
こう書いて
ここのデータロードを書いたときは
引数がここに使えるようになるので
Ippei Usami
ターゲット
エクセプト
binnmti
こう書く形になります
これを書き方をすると
何がおいしいかというと
データローがいくつでも並べられる
ここだけ書き換えれば
これが1つ目のテストになって
次のデータローが2つ目のテストになって
次のデータローが3つ目のテストになるので
メンテナンシビリティが
良くなる
実際に今これ
リートコードのテストを書いてみると
2問目が
1と6なんで
ここは2と3
4の6で
答えが
1と3
Ippei Usami
だから1と3
binnmti
3問目が
1と2か
Ippei Usami
これ1と2ですね
これプラス1
多分配列の
binnmti
リネックスじゃなくて
Ippei Usami
プラス1
binnmti
1問目の2と3と
若干だけ違うところは
ここが違うはず
微妙に違います
もし1問目の2と3と
全く同じにやると
これハマるかなと思うので
こんな感じですね
こんな感じで書くと
パラメタライズなテストができるようになるので
実際にテストをしてみると
1番目2番目3番目というのが
ここに入ってくるので
プラスよりは
パラメータでテストしたほうが
Ippei Usami
いいかなって
間違えちゃった
binnmti
気合なら1番簡単にできると思う
Ippei Usami
レーラーが
レーラーでやれば書けばできそうな気がするんですけど
二重ループいける?
どんな二重ループ?
二重っていうか
binnmti
リンクとか使えばたぶん
Ippei Usami
もういらない
binnmti
そうですね
でもそれでも結局なんか
Ippei Usami
力技完成なんで
何かも変わらないので
binnmti
見た目はちょっと気になると思うんで
何かが必要なのは変わらないので
一旦今日はステップバイステップで
いこうと思っているので
二重ループで解いてもらってもいいかなって
Ippei Usami
思います
時間切れの演習だ
考えすぎなところある
しばらくこれ書いてあるの分かっちゃう
何でだろう
binnmti
実際に解けたら
リードコーナーのほうの
2サブのところに
コードを貼ってもらって
サブネットってやれば
ログインしてれば
リードコードのほうで
全テストを同時にしてくれます
Ippei Usami
ステップバイス
binnmti
リードコーナーで
小人の歌フェイスがいるんだ
Ippei Usami
歌フェイス?
binnmti
1番
13の1番
Ippei Usami
歯がちょっといる
binnmti
なるほど
Ippei Usami
思ったよりいろいろ書いてる
binnmti
もう一人できたら
レビューっぽい感じに
しておこうかなって
Ippei Usami
思います
リードコードの1番
binnmti
2つの合計って意味では
同じ問題なんですけど
ここにヒントも書いてあるので
Ippei Usami
なんとなくヒントを見ながらに しようかなって思います
binnmti
本当に強引な方法は
全ての可能な数字のシェアを 検索することですが
Ippei Usami
それでは時間がかかりすぎます
全部回せるみたいな感じですね
binnmti
完全性のために強引なソリューションを 試してみるのが最善です
つまりそれでもいいから解いてみろって 言ってる気がします
Ippei Usami
すげえかと思う
ほんまに工業6条ぐらいだと思うんだけど
ちょっとね
とりあえず頭使っちゃう
最近帰れないからどうやったかな
これランタイムの評価もしてくれます
binnmti
ランタイム?
実行時間も
早いか遅いかまで
Ippei Usami
それはどうするか
binnmti
テスト結果のほうでやると
順位っぽいものまで出してくれますね
Ippei Usami
順位の変化とかみたいな
binnmti
これはちょっと後で 説明しようかと思ってましたけど
Ippei Usami
そこは頑張らないほうがいいです
binnmti
計算量の話とかをした後で
その理由とかはちゃんと言うつもりですけど
ここを早くするには
まずは計算量を抑えることがあって
それよりも早くしようとしだすと
本質的ではない考えが必要になってくるし
リートコードの裏の事情というか
Ippei Usami
教えてもらった話で言うと
binnmti
課金したほうが若干早くなる
CPUの性能が良いものになるから
解くときも良いものになるので
Ippei Usami
順位が上がりやすい
そこを頑張ってもしょうがないかなと思うので
binnmti
なので計算量を上げて早くするというのは
頑張りましょうと思うんですけど
1位を目指しましょうは
だいぶ違った方向性の努力になってくるので
Ippei Usami
やめたほうがいいかなと思う
どうですか?
笑ってしまうな
binnmti
アルゴリズム問題解いてると
普段使わない頭のルールを使う感じがするので
Ippei Usami
久しぶりに閉じてきやすいな
多分時間以外になっちゃう
binnmti
そうですね
そろそろ1回考えてた時間にはなってきたので
どうですかみんな?
Ippei Usami
もうちょい考えたいのか
1回解いた人の話を聞きたいかというと
もうちょい考えたいのか
考えるじゃなくても力が足らない
うさみさんも?
そうですね
binnmti
それが終わったら
Ippei Usami
遠藤さんの立ち方を聞きましょうか
今ちょっと変わらなくなりました
binnmti
前のやつまでできます
それでもいいですけどね
本質的にはあんまり変わらないので
Ippei Usami
うさみさんもうちょいだけ待ちましょうか
無意味じゃないですか
うまくやったような感じですけど
内側と外側が書いてきて
ようやく外側が書きかけたんだけど
さてどうやって終了条件を決めようか
終了条件は?
あと最期的に
どこから最期にしようか
binnmti
最期は使わなくてもいけますね
Ippei Usami
最期使わなくてもいけます?
いけますね
binnmti
多分ね複雑に考えすぎてる気が
後半を見ても分かる
それはめっちゃ知りました
Ippei Usami
そう考えちゃったでしょ
ただ方針は
絵も非常に長いと思ってるんだけど
どこにしようかなと思った
感動しに来ました
え?なんで?
多分ダメだったやつだ
binnmti
捕まらなかったときに戻るしかないって
Ippei Usami
いる気がしますね
答えは一応絶対あるよっていう
答えは絶対あるって言ってますけど
一旦入力しておけば
解くことの重要性
binnmti
プロジェクト部とかだったら
最高に例外
例外プロジェクトから
Ippei Usami
頂いた方がいいと思うんですけど
思いました
誇りまし
binnmti
誇りまして
Ippei Usami
確かに
一応ね
binnmti
はい
Ippei Usami
簡単に
binnmti
じゃあ遠藤さんがどう書いたかを
ちょっと聞きますか
Ippei Usami
これ繋げますか
binnmti
こっちに来てもらっていいですか
Ippei Usami
そうですね来てもらったほうがいい
はいじゃあ遠藤さんちょっと
binnmti
応募を出してもらいながら
Ippei Usami
反省を
自分にやったのに3パターン
binnmti
3パターンそんなに?
3パターン僕が用意したやつです
ちなみに遠藤さん
じゃあ二重ループよりも
Ippei Usami
早い方法で解いてもらっていいですか
はい
binnmti
まず二重ループから
話をするのがいいかなと
思っているので
Ippei Usami
同じ数字入る
コードしたやつ
これが最初のやつ
binnmti
なんとなくどう考えたかを
説明しながら
説明してもらえますか
Ippei Usami
まずこういう
一つ目
binnmti
こういうメソッドを用意して
ここには小順の
数字があります
ここには2つの
ターゲット1の数字があります
配列を12あるいは0から
配列の最初から最後まで
Ippei Usami
並べていきます
binnmti
もう一つのループを用意して
Ippei Usami
ループ中のインデックスを
binnmti
次から最後まで
Ippei Usami
はいはいはい
どんどん並べていきます
binnmti
そのまま
ターゲットを用意してもらったら
プラスインチしたわけです
素晴らしい
二重ループのお手本のような
Ippei Usami
答えかなって思います
そうですね
計算量の考え方
binnmti
ちなみに計算量の考え方って
Ippei Usami
知ってる人います?
binnmti
考え方の話?
Ippei Usami
あ、そうです
binnmti
これ計算量いくつかって
計算量の話を
少し先にしようかなって思うので
一旦変わってもらおうかな
Ippei Usami
変わってもらいます
はい
binnmti
ここからはちょっと説明を
Ippei Usami
説明ページ
binnmti
パラメトライズテスト書いて
僕も結構同じ感じで解いてます
二重ループ作って
ここはif文にして
遠藤さんはコンティニューしてましたっけね
Ippei Usami
これがノットの時は
binnmti
ここでリタニカル
ほとんど一緒のコードかなって思います
アルゴリズム問題を解く時の
鉄則というか考え方で
Ippei Usami
このコードの計算量はいくつですかっていうのを
binnmti
基本的には意識して解く方が良いです
はい
計算量これ実際に
intのナンバーズに入ってきてるのが
テスト1だったら4個あったと思うので
一つ目のテストだったらOの4
まず最初のループは4回回る
二個目のループは
4-i-1からなんで3回回る
二つ目のテストは3個あたりが入ってたので
連打数は3なので
Ippei Usami
3と2だし
binnmti
最後のテストは2個入ってたので
2と1が入りますと
まず計算量を考える時は
実際にいくつになるかなっていうのを
考えてみます
計算量を解く時には
Ippei Usami
ルールみたいなのがあります
binnmti
すごく簡単に言うと
Ippei Usami
例えば
binnmti
このループって二重ループになってるので
二重ループの場合は
xかけるxになるので
x次乗みたいな考え方をします
その場合より正確に書いていくと
さっき言った4とか5みたいな数字が出てくると思うんで
5xの次乗を足す10x足す2みたいな
そういう形に計算量自体はなると思います
ただし最高次数
つまりこの場合だと
xの次乗が一番大きくて
次が10のxで
最後がxがない状態なので
最高次数である
まず5xの次乗だけを考えて
残りの少ないやつに関しては
Ippei Usami
切り捨てます
binnmti
さらに係数
今回だと5xの次乗なんですけど
5をなくします
つまりこれの計算量は
xの次乗
nを使うことが多いので
oのnの次乗
Ippei Usami
っていう考え方になります
binnmti
計算量は
今チキした方がいいって言ったんですけど
まずはやっぱ問題なんで
解くことが重要なので
計算量云々は
解いて後に考えることが良いかなと思ってて
ほとんどの問題は層あたりで解けば
大体は解けるはずなので
まずは解きましょう
二分探索の計算量
binnmti
解けた後に
計算量っていうのを考える
っていう習慣を作るのが
いいかなって思います
この
5以外は落とすとか
係数を無視するっていうのが
僕もこれ最初意味が分からなかったんですけど
なんでこれをこういう風に考えられるか
Ippei Usami
っていうのが一つが
binnmti
nで回した時の回数と
nの次乗の時の回数みたいなのを
比較した数字があって
例えばnを100回回した場合に
もしそれが20ループになってて
nの次乗だったら
そのループが何回回るかというと
1万回回るんですよね
ここが例えば2
Ippei Usami
つまり
binnmti
20ループじゃなくて
20ループが2回回るだったら
200回にしかならないわけなんですよね
だけどnの次乗だったら
1万回になるんですよね
200回と1万回って
もう言ったら誤差みたいなもんだので
そこは気にしなくてもいいだろう
Ippei Usami
っていう考え方なんですよね
binnmti
だからこの上に書いてあるような
log n n n log n n 次乗
かどうかっていうのは
気にする必要があると思うんですけど
これが5nなのか10nなのかっていうのは
基本的にはさっぴいて考えてしまえば
Ippei Usami
良いっていう考え方です
binnmti
1問目をやめた理由はなぜかというと
あれ2nで解けるんですよね
20ループにした場合
そうすると計算量の話をした時に
Ippei Usami
nの次乗じゃなくてnになってしまうので
binnmti
多分nの解き方
最適な解き方
最速の解き方なので
ちょっとこの説明をするのに
あんまり良くないなって思ったので
Ippei Usami
今回はあの問題をちょっと変えました
binnmti
実際グラフで見ると
すごく分かりやすいと思うんですけど
nの次乗の時は
もうまっすぐに進まずに
反比例的に進んでしまうので
実際これでも100回がnの次乗だったら1万回
1万回ぐらい回すことって
全然あると思うんですけど
1万回だったら100万回を越してしまうので
実践ではほぼほぼ使えないんじゃないか
っていうレベルになります
なので理想論として
計算量を求めるときっていうのは
n二乗以上だと
そのループを1万回回すってなっただけでも
100万回回るので
実践的には結構使いづらい状態になってしまうので
できればnログn以下を目指すのが
Ippei Usami
いいとされています
binnmti
nログnだったら1万回回しても
13万回
これでもちょっと多いんですけど
実践で耐えるぐらいなのかなっていうのが
Ippei Usami
このグラフの考え方なので
binnmti
でもさっきも言った通り
細かい2nとかはわりとどうでもいい
っていう考え方をしないといけない
話し手1はいどうぞ
Ippei Usami
話し手2はい
binnmti
話し手21個前の計算だと
2nで解けるか分かりません
話し手2ああ
えっと1問目って
ここ多分2個見ればすぐ
一緒にある問題
話し手2ああ
だから
Ippei Usami
話し手21問目?ごめんなさい
binnmti
話し手2今回リードコードの
1問目じゃなくて
Ippei Usami
107問目にしたじゃないですか
binnmti
167問目にしたじゃないですか
Ippei Usami
話し手2最初に出てた
binnmti
話し手2あの問題って
ここが2で解けるんですよね
ナムレンジじゃなくて
ここが2になってしまうと
ここの計算量って
Ippei Usami
Oの2になっちゃうんですね
binnmti
話し手2定数になっちゃうってこと?
話し手2そうそう定数になっちゃう
だから2nになるんで
このn事情にならないんで
話が静かになるんでやられました
そういう話で
Ippei Usami
話し手2そうだったよ問題が
私に言い忘れてたんだ
言い忘れてたんだ
binnmti
話し手2わかりません
はい
話し手2言い忘れてた
話し手2元の問題いきましょうか
Ippei Usami
話し手2元の問題は
binnmti
話し手213の1
リードコードの1
Ippei Usami
話し手2今回の問題1番ですよね
話し手2はい
binnmti
これは
まずこの数字全部をループで回して
そのループの中で2個
Ippei Usami
次のだけ見れば多分解けるんですね
binnmti
話し手2高いで
話し手2はい2回ですね
話し手2でもワーストケースでは
Ippei Usami
M以上じゃないんですよね
binnmti
話し手2そうだね
話し手2多分ちょっと今パッと
Ippei Usami
話し手2そう
ワーストケースの条件
話し手2はい
話し手2M以上じゃないの
話し手2M以上ですね
話し手2M以上でしか解けないなと
binnmti
これだけ見るとダメなはず
話し手2ダメでしたっけ
Ippei Usami
話し手2問題が多分
binnmti
324と悩んでた場合
3つに2見れば
Ippei Usami
終わるってわけではない
話し手2最悪ケースは
今日全部知られた
binnmti
話し手2これじゃ解けなかったでしたっけ
話し手2全部舐める必要性は少なく
Ippei Usami
2問目は全部舐めないと
binnmti
話し手2じゃあ僕の勘違いかも
Ippei Usami
失礼しました
binnmti
これで解けると思ったけど
Ippei Usami
これじゃ解けないのか
binnmti
話し手2それはできないパターンがあります
Ippei Usami
1問目は少ないと思って
今さっき言ったのが
大正論だったら報道でしか解けないと思う
binnmti
話し手2なるほど
僕多分いろいろやった時
勘違いしたのかもしれない
1問目でもよかったんですけど
あえて違う問題にしたのは
Ippei Usami
それはそれで面白いかと思った
話し手21問目だと
1問目にならないより
効率よくならないよなと思って
話し手2はいはいはい
ごめんなさいちょっとミスりました
binnmti
でもう一つと
で結構これ重要な注意点なんですけど
ライブラリを使ったり
リンクを使ったりすると
Cシャープで書けると思うんですけど
そのライブラリも
当然中では計算してますと
だから一見この上のやつ
二重ループに見えない形だと思うんですけど
ファーストってどうやって実装するかっていうのを
ちょっと考えてみると分かるんですけど
ファーストってその数字が出てくるまで
ループで回して
見つかったら終わるってやるんですよね
ってことはループを書いてるんですよね
つまりこの一見一重のループしかないようにやって
内容的にどうやって考えるかと
二重ループになってるので
計算量はNの事情になります
なのでライブラリ使うときは
ライブラリの計算量も若干意識する必要があります
binnmti
アルゴリズム問題解くときは
縛りプレイでライブラリ使わない
みたいなことをする人も中にはいるので
そういうことを意識してみると
ライブラリ使うときでも
どれが早いかなみたいなことは
意識しやすくなるかなって思います
ハッシュを使う方法
binnmti
こっちのテストの方の話なんで
Ippei Usami
遠藤さん計算量さらに早い解き方もしてみたんでしたっけ
binnmti
はい
じゃあそれを聞きつつ
早いかどうかは実際に測ったわけではないので
これの一個前にCで書いたんですよ
Ippei Usami
Cシャープの解き方を
binnmti
それからCシャープに移植というか
なるほど
Cシャープから入ったら
遠藤的に書けなかったか
井上さんも計算量で言えばN事情じゃない?
Ippei Usami
多分リンク使ってるだけなので
多分N事項だと思います
多分そう
binnmti
外の最初ループ回して
Ippei Usami
残りの部分から
ファインドインデックスしてるだけなんで
なるほど
ファインドインデックスの実装が分からないんで
あれなんですけど
リンク使ってるから
二つ目です
binnmti
Nログ2
Ippei Usami
NログN
binnmti
バイナリーサーチを
配列が小順という前提で
バイナリーサーチを使います
同じように配列を順に舐めていって
Ippei Usami
そこから
次の要素から最後までの間で
binnmti
数値を探します
探す数値はターゲットマイナス
今のインデックスの数値で
計算できます
ナンバーで配列から
バリューでファインドという
Ippei Usami
数値を
iから
iじゃないな
iプラス1
修正すると
binnmti
iプラス1から
最後の要素
バイナリーサーチをしていきます
Ippei Usami
それがファインドインデックスという
リソットです
binnmti
リフトとライトのインデックス
を順にして
Ippei Usami
センターを探して
binnmti
そのセンターのインデックス
求める値が大きいか小さいかで
Ippei Usami
どんどん
binnmti
インデックスを変えていきます
最後まで計算して
Ippei Usami
センターのところが
binnmti
インデックスの値が
Ippei Usami
求める値と同じだったら
インデックスを加えします
binnmti
見つからなかったら
Ippei Usami
ルールを変えます
という風にして求めます
binnmti
2分探索で
要素が5個あったら
真ん中を見に行って
大きいか小さいか見て
大きい方にあればこっちに行って
というので
Ippei Usami
ポンポンポンで行けるという話です
binnmti
それは計算量でいうと
ログNですよね
ルー