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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Python 3.x

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

Q&A

解決済

1回答

2896閲覧

python Atcoder問題 実行時間超過 原因

nkmur

総合スコア5

Python 3.x

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

0グッド

0クリップ

投稿2019/09/29 05:18

編集2019/09/29 05:28

前提・実現したいこと

下記の問題を解いて提出をしました。
https://atcoder.jp/contests/abc142/tasks/abc142_c

自分の提出したコードが実行時間超過となりました。
超過してしまった原因を知りたいです。

発生している問題・エラーメッセージ

自分の提出したコードが実行時間超過となりました。

特になし

該当のソースコード

N = int(input()) A = list(map(int, input().split())) B = [] for x in range(1,N+1): m = A.index(x) + 1 B.append(m) print(*B)

試したこと

A = tuple(input().split())

Aへの入力をtupleにしてみたりしてもダメでした。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

python

1for x in range(1,N+1): 2 m = A.index(x) + 1

ここがおそいです。O(N^2)程度かかりますが、N=10^5でこの計算は間に合わないです。
A.index(x)は前から一個ずつ探すので時間がかかります。
例えば

python

1B = [0] * (N + 1) 2for i in range(N): 3 B[A[i]] = i

してから、B[1:]をprintしてやるといいです。

投稿2019/09/29 05:50

編集2019/09/29 05:54
fukatani

総合スコア626

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問