AtCoder競プロ典型90問、10問目score sum queries についてですが、私の回答は以下です。
python
1n = int(input()) 2 3CP = [list(map(int, input().split())) for _ in range(n)] 4 5q = int(input()) 6 7for i in range(q): 8 lans = 0 9 rans = 0 10 l, r = map(int, input().split()) 11 for j in range(l-1, r): 12 if CP[j][0] == 1: 13 lans += CP[j][1] 14 else: 15 rans += CP[j][1] 16 print(lans, rans)
これではTLEになってしまいます。そして、以下のコード
python
1n = int(input()) 2 3C = [] 4P = [] 5for i in range(n): 6 c, p = map(int,input().split()) 7 C.append(c) 8 P.append(p) 9 10q = int(input()) 11 12L = [] 13R = [] 14for i in range(q): 15 l, r = map(int,input().split()) 16 L.append(l-1) 17 R.append(r) 18 19tmp1 = 0 20tmp2 = 0 21sum_score = [[0, 0]] 22for i in range(n): 23 if C[i] == 1: 24 tmp1 += P[i] 25 else: 26 tmp2 += P[i] 27 sum_score.append([tmp1, tmp2]) 28 29for k in range(q): 30 A = sum_score[R[k]][0] - sum_score[L[k]][0] 31 B = sum_score[R[k]][1] - sum_score[L[k]][1] 32 print(str(A) + " " + str(B))
これだとACになります。まだまだ初心者で処理速度のことがよくわかっていないのですが、後者の方がかなり速くなるのはなぜですか?素人考えでは後者の方が面倒くさい処理をしているように感じてしまいます。for文を二重にすることは処理速度の面では悪手でしょうか。そして、処理を速くするために学ぶべき知識があれば教えていただけると嬉しいです。よろしくお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。