結果

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

ソースコード

diff #

n=int(input())
ops=['#']*n;a=[0]*n

divmode=0
for i in range(n):
	ops[i],at=input().split()
	a[i]=int(at)
	if ops[i]=="/":
		divmode=1

ans=[]


if divmode:
	ans.append(f"add b b A[1]")

for i in range(n):
	if ops[i]=='+':
		if divmode:
			ans.append(f"mul c A[{i+1}] b")
			ans.append(f"add a a c")	
		else:
			ans.append(f"add a a A[{i+1}]")
	elif ops[i]=='*':
		ans.append(f"mul a a A[{i+1}]")
	elif ops[i]=='/':
		ans.append(f"mul b b A[{i+1}]")
		mode=1

if divmode:
#	ans.append(f"mul a A[i] A[1]")
	ans.append(f"div a a b")

print(len(ans))
for s in ans:
	print(s)
0