結果

問題 No.3502 GCD Knapsack
コンテスト
ユーザー nasu
提出日時 2026-04-18 01:12:15
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
TLE  
実行時間 -
コード長 1,033 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 200 ms
コンパイル使用メモリ 85,248 KB
実行使用メモリ 1,048,576 KB
最終ジャッジ日時 2026-04-18 01:12:53
合計ジャッジ時間 8,290 ms
ジャッジサーバーID
(参考情報)
judge1_0 / judge3_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample -- * 3
other TLE * 1 MLE * 1 -- * 33
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

n, w = map(int,input().split())
x = list(map(int,input().split()))
y = list(map(int,input().split()))

def GCD(a, b):
    while b != 0:
        tmp = b
        b = a % b
        a = tmp
    return a

rng = max(x) - w
if rng < 0:
    print(0)
    exit(0)

stack = [(0,0)]
for i in range(n):
	if x[i] < w:
		  continue
	l = len(stack)
	for j in range(l):
		  gcd = GCD(stack[j][0], x[i])
		  if gcd >= w:
		    stack.append((gcd,stack[j][1]+y[i]))
		  stack.append((x[i],y[i]))
      
print(max(stack, key=lambda x: x[1])[1])
exit(0)


dp = [[0 for _ in range(rng+1)] for _ in range(n+1)]
offset = 0
for i in range(n):
    if x[i] < w:
        offset += 1
        continue
    idx = i - offset
    dp[idx+1][x[i]-w] = max(y[i], dp[idx+1][x[i]-w])
    for j in reversed(range(rng)):
        if dp[idx][j] <= 0:
            continue
        dp[idx+1][j] = max(dp[idx][j], dp[idx+1][j])
        gcd = GCD(w+j, x[i])
        if gcd >= w:
            dp[idx+1][gcd-w] = max(dp[idx+1][gcd-w], dp[idx][j]+y[i])
print(max(0,max(dp[n-offset])))
0