結果
問題 | No.1650 Moving Coins |
ユーザー |
![]() |
提出日時 | 2021-08-20 23:00:22 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 688 ms / 2,000 ms |
コード長 | 872 bytes |
コンパイル時間 | 152 ms |
コンパイル使用メモリ | 12,928 KB |
実行使用メモリ | 49,560 KB |
最終ジャッジ日時 | 2024-10-14 06:12:57 |
合計ジャッジ時間 | 13,610 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 24 |
ソースコード
from collections import dequeN = int(input())A = list(map(int, input().split()))B = list(map(int, input().split()))def is_movable(n):if A[n] == B[n]:return Falseelif A[n] < B[n]:if n == N - 1:return Trueelse:return B[n] < A[n + 1]elif A[n] > B[n]:if n == 0:return Trueelse:return B[n] > A[n - 1]result = []q = deque(range(N))while q:i = q.popleft()if not is_movable(i):continueif A[i] < B[i]:moves = B[i] - A[i]dir = 'R'elif A[i] > B[i]:moves = A[i] - B[i]dir = 'L'for j in range(moves):result.append('%d %s' % (i + 1, dir))A[i] = B[i]if i != 0:q.append(i - 1)if i != N - 1:q.append(i + 1)print(len(result))print(*result, sep='\n')