結果

問題 No.2408 Lakes and Fish
ユーザー irohasu19_irohasu19_
提出日時 2023-08-13 14:32:24
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
WA  
実行時間 -
コード長 1,073 bytes
コンパイル時間 280 ms
コンパイル使用メモリ 12,928 KB
実行使用メモリ 28,752 KB
最終ジャッジ日時 2024-11-21 10:12:59
合計ジャッジ時間 11,420 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 28 ms
10,880 KB
testcase_01 AC 29 ms
10,880 KB
testcase_02 AC 28 ms
10,880 KB
testcase_03 AC 28 ms
10,880 KB
testcase_04 AC 616 ms
28,044 KB
testcase_05 AC 609 ms
28,108 KB
testcase_06 AC 589 ms
27,968 KB
testcase_07 AC 655 ms
28,752 KB
testcase_08 AC 654 ms
27,776 KB
testcase_09 AC 655 ms
27,608 KB
testcase_10 AC 662 ms
27,656 KB
testcase_11 AC 377 ms
19,804 KB
testcase_12 WA -
testcase_13 AC 135 ms
14,968 KB
testcase_14 AC 293 ms
17,984 KB
testcase_15 AC 544 ms
25,104 KB
testcase_16 AC 166 ms
16,352 KB
testcase_17 AC 171 ms
14,692 KB
testcase_18 AC 301 ms
19,136 KB
testcase_19 WA -
testcase_20 WA -
testcase_21 AC 554 ms
25,408 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

import bisect

n, m = map(int, input().split())
L = list(map(int, input().split()))
F = []
B = []
W = []

for _ in range(m):
  li = list(map(int, input().split()))
  F.append(li[0])
  B.append(li[1])
  W.append(li[2])

total_cost = 0
is_move = [False]*m

#Lの先頭と末尾に番兵を追加することで場合分けが不要になる
INF = 1000000010
L[:0] = [-INF]
L.append(INF)
for i in range(m):
  ind_1 = bisect.bisect_left(L, F[i])
 # if ind_1>0 and ind_1 < n:
  ind_2 = ind_1 - 1
  cost = min(abs(F[i]-L[ind_1]), abs(F[i]-L[ind_2]))
  if cost < (W[i]-B[i]) :
    is_move[i] = True
    total_cost += cost
  else:
    continue
  # elif ind_1 == 0:
  #   cost = abs(F[i]-L[ind_1])
  #   if cost < (W[i]-B[i]) :
  #     is_move[i] = True
  #     total_cost += cost
  # elif ind_1 == n:
  #   cost = abs(F[i]-L[ind_1-1])
  #   if cost < (W[i]-B[i]) :
  #     is_move[i] = True
  #     total_cost += cost
      
total_score = 0
for j in range(m):
  if is_move[j]:
    total_score += W[j]
  else:
    total_score += B[j]

total_score -= total_cost
print(total_score)


0