質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

566閲覧

AtCoder ABC201-BのWAの理由を教えて下さい。

Watarungurunnn

総合スコア6

Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/05/29 08:23

編集2021/05/29 09:32

テストケースの2/10がWAになります。正答率からしてNが極小か極大で間違っていると推測はしているのですが手詰まりになってしまいましたため、どこが間違っているか教えていただけますでしょうか?

python3

1 2def merge_sort(aList): 3 if len(aList) <= 1: 4 return aList 5 6 mid = len(aList) // 2 7 left = aList[:mid] 8 right = aList[mid:] 9 10 left = merge_sort(left) 11 right = merge_sort(right) 12 13 return merge(left, right) 14 15 16def merge(left, right): 17 sorted_list = [] 18 left_index = 0 19 right_index = 0 20 21 while left_index < len(left) and right_index < len(right): 22 if left[left_index][1] <= right[right_index][1]: 23 sorted_list.append(left[left_index]) 24 left_index += 1 25 else: 26 sorted_list.append(right[right_index]) 27 right_index += 1 28 29 if left: 30 sorted_list.extend(left[left_index:]) 31 if right: 32 sorted_list.extend(right[right_index:]) 33 34 return sorted_list 35 36 37N = int(input()) 38L = [] 39A = [list(input().split()) for _ in range(N)] 40for i in range(N): 41 L.append([A[i][0], int(A[i][1])]) 42 43print(merge_sort(L)[-2][0])

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

自己解決

int型にせずにソートしていたのがいけなかったようです。また、marge_sort()のreturnをlistになっていたため、最終outputのindexがきちんと指定できていませんでした。

python3

1def merge_sort(aList): 2 if len(aList) <= 1: 3 return aList 4 5 mid = len(aList) // 2 6 left = aList[:mid] 7 right = aList[mid:] 8 9 left = merge_sort(left) 10 right = merge_sort(right) 11 12 return merge(left, right) 13 14 15def merge(left, right): 16 sorted_list = [] 17 left_index = 0 18 right_index = 0 19 20 while left_index < len(left) and right_index < len(right): 21 if left[left_index][1] <= right[right_index][1]: 22 sorted_list.append(left[left_index]) 23 left_index += 1 24 else: 25 sorted_list.append(right[right_index]) 26 right_index += 1 27 28 if left: 29 sorted_list.extend(left[left_index:]) 30 if right: 31 sorted_list.extend(right[right_index:]) 32 33 return sorted_list 34 35 36N = int(input()) 37L = [] 38A = [list(input().split()) for _ in range(N)] 39for i in range(N): 40 L.append([A[i][0], int(A[i][1])]) 41 42 43if N == 2: 44 if L[0][1] > L[1][1]: 45 print(L[1][0]) 46 else: 47 print(L[0][0]) 48else: 49 print(merge_sort(L)[-2][0])

投稿2021/05/29 09:29

Watarungurunnn

総合スコア6

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

以下の入力例で、正しい出力はaですが、このコードだとbが表示されます。

text

12 2a 2 3b 10

投稿2021/05/29 08:34

actorbug

総合スコア2231

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Watarungurunnn

2021/05/29 09:11

具体的にどう違うのか教えていただけますでしょうか。
actorbug

2021/05/29 09:26 編集

数値を文字列として比較しているのが間違い。 2 < 10 だけど "2" > "10" となる。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問