結果

問題 No.3278 Avoid Division
ユーザー navel_tos
提出日時 2025-09-20 03:32:13
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 1,098 bytes
コンパイル時間 348 ms
コンパイル使用メモリ 82,820 KB
実行使用メモリ 54,892 KB
最終ジャッジ日時 2025-09-20 03:32:40
合計ジャッジ時間 4,291 ms
ジャッジサーバーID
(参考情報)
judge2 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 20 WA * 4
権限があれば一括ダウンロードができます

ソースコード

diff #

#yukicoder3278 Avoid Division

def solve():
    N = int(input())
    query = [tuple()] * N
    for i in range(N):
        op, Ai = input().split()
        query[i] = (op, int(Ai))

    #all add
    if all(op == '+' for op, _ in query):
        print(N)
        for i in range(1, N + 1):
            print(f'add a a A[{i}]')

    #そうでない場合: 普通に解く
    else:
        ans = []
        bunbo_flag = 0
        for i, (op, _) in enumerate(query, start = 1):
            if   op == '+':
                if bunbo_flag == 0:
                    ans.append(f'add a a A[{i}]')
                else:
                    ans.append(f'mul c b A[{i}]')
                    ans.append(f'add a a c')
            elif op == '*':
                ans.append(f'mul a a A[{i}]')
            elif op == '/':
                if bunbo_flag == 0:
                    ans.append(f'add b b A[{i}]')
                    bunbo_flag = 1
                else:
                    ans.append(f'mul b b A[{i}]')
        ans.append(f'div a a b')
        print(len(ans))
        print(*ans, sep = '\n')

solve()
0