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

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

ただいまの
回答率

88.58%

標準入力をリスト(辞書)化したのち、特定のバリュー(max、minなど)のインデックスを表示するには

解決済

回答 4

投稿

  • 評価
  • クリップ 0
  • VIEW 1,703

gyanonsh

score 19

データが標準入力として以下のように与えられます。
#データの個数
5
#データ
10 25
10 54
41 62
45 11
14 12

ここで、データの左の数字から右の数字の差が上位3番目までの
インデックスを表示したいのです。
以下のように、2次元リスト化して左の数字をc、右の数字をdとするとこまで
いったのですが、この後「差」を出していこうにも、インデックスの表記を
どうすればいいのかがわかりません。
enumerateメソッドを使うのか、indexメソッドを使うのか
いろいろ試したのですが、出力までこぎつけれません。
どなたか、ご教授下さい。

a= input().split()
A=int(a)
my_list=[]
for i in range(A):
my_list.append(input().split())
c = my_list[i][0]
d = my_list[0][i]

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 4

checkベストアンサー

+1

以下のように、2次元リスト化して左の数字をc、右の数字をdとするとこまで
いった

for i in range(A):
    my_list.append(input().split())
    c = my_list[i][0]
    d = my_list[0][i]

いえ、できていないです。
実際に c と d の値を覗いてみると良いでしょう。

# a= input().split()

a= int(input())
A=int(a)
my_list=[]

for i in range(A):
    my_list.append(input().split())
    c = my_list[i][0]
    d = my_list[0][i]

    print(c, d)

実行結果 Wandbox

10 10
10 25
Traceback (most recent call last):
  File "prog.py", line 8, in <module>
    d = my_list[0][i]
IndexError: list index out of range

まずは差のリストを作ることから始めましょう。
次のようなリストを作れれば、問題の半分は解けたと言っても良いでしょう。

>>> diffs
[15, 44, 21, -34, -2]

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/10/15 18:10

    a= input()
    A = int(a)
    list_01 = []
    list_02 = []
    for i in range(A):
    x1,y1=[int(i) for i in input().split()]
    list_01.append(x1)
    list_02.append(y1)
    diff = [x-y for (x, y) in zip(list_01, list_02)]
    index_max = diff.index(max(diff))+1
    print(index_max)

    キャンセル

  • 2018/10/15 18:11

    コメント欄では行頭のスペースが削除されますので、質問を編集して追記する形にすると良いでしょう。

    キャンセル

  • 2018/10/15 18:52

    なるほど。そのとおりですね。
    いつもありがとうございます!

    キャンセル

+1

差のリストを先に作ってから、enumerateでインデックスと組みにして、sortedでkeyをうまく指定してソートすればよいかと思います。

 追記

n = int(input())

diff_lst = []
for _ in range(n):
    a, b = map(int, input().split())
    diff_lst.append(a-b)

for i, d in sorted(enumerate(diff_lst), key=lambda x:x[1], reverse=True)[:3]:
    print(i)

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/10/15 18:04

    hayatakaさん
    ありがとうございます。
    色々な関数とかメソッドを使って、チャレンジするのですが、
    それぞれの関数などが対応する型を理解していないので
    なかなか、カチっとこないのが問題です。。
    悔しいですねぇ・・。

    キャンセル

  • 2018/10/15 21:19 編集

    この手の問題でうまくいかないときはたいてい難しく考えすぎなので、とりあえずシンプルに考えることをおすすめします。

    キャンセル

  • 2018/10/17 12:57

    >難しく考えすぎ。。 最近そう思います。ありがとうございました!

    キャンセル

0

numpy を使うのがおすすめです。

 手順

  1. 行ごとに差の絶対値を計算する。(numpy.abs())
  2. 昇順ソートする。(numpy.agrsort() で降順ソートし、[::-1] で反転させる。)
  3. 差が大きい上位3つのインデックスを取り出す。([:3])

 サンプルコード

import numpy as np

# 入力を受け付ける。
data = []
for i in range(2):
    values = input('空白区切りで2つの数字を入力してください。 (例: 1 5)').split()
    data.append(list(map(int, values)))
data = np.array(data)
print(data)

# 行ごとに差を計算する。
diff = np.abs(data[:, 0] - data[:, 1])
print(diff)  # [15 44 21 34  2]

# 昇順ソートする。
indices = np.argsort(diff)[::-1]
print(indices)  # [4 0 2 3 1]

for i, index in enumerate(indices):
    print('上位 {} 番目に差が大きい行 {} 値 {}'.format(i + 1, index, data[index]))
# 上位 1 番目に差が大きい行 1 値 [10 54]
# 上位 2 番目に差が大きい行 3 値 [45 11]
# 上位 3 番目に差が大きい行 2 値 [41 62]
# 上位 4 番目に差が大きい行 0 値 [10 25]
# 上位 5 番目に差が大きい行 4 値 [14 12]

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

A= int(input())
list_01 = []
list_02 = []
for i in range(A):
    x1,y1=[int(i) for i in input().split()]
    list_01.append(x1)
    list_02.append(y1)
    diff = [x-y for (x, y) in zip(list_01, list_02)]
    index_max = diff.index(max(diff))+1
print(index_max)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 88.58%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る