結果
問題 | No.1243 約数加算 |
ユーザー | ygd. |
提出日時 | 2020-10-02 22:07:24 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 90 ms / 2,000 ms |
コード長 | 574 bytes |
コンパイル時間 | 257 ms |
コンパイル使用メモリ | 86,856 KB |
実行使用メモリ | 76,740 KB |
最終ジャッジ日時 | 2023-09-24 12:36:01 |
合計ジャッジ時間 | 1,882 ms |
ジャッジサーバーID (参考情報) |
judge11 / judge14 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 67 ms
71,200 KB |
testcase_01 | AC | 67 ms
71,380 KB |
testcase_02 | AC | 67 ms
71,476 KB |
testcase_03 | AC | 71 ms
75,800 KB |
testcase_04 | AC | 90 ms
76,632 KB |
testcase_05 | AC | 87 ms
76,740 KB |
testcase_06 | AC | 89 ms
76,580 KB |
testcase_07 | AC | 84 ms
76,648 KB |
testcase_08 | AC | 87 ms
76,700 KB |
testcase_09 | AC | 72 ms
75,364 KB |
ソースコード
T = int(input()) for case in range(T): A,B = map(int,input().split()) if B-A <= 120: #20: print(B-A) ans = [1]*(B-A) print(*ans) continue ans = [] Flag = False for i in range(120): tempA = A*1 kaisu = 0 while tempA%2 == 0: kaisu += 1 tempA //= 2 beki = pow(2,kaisu) if B <= A+beki: nokori = B - A for j in reversed(range(kaisu)): if (nokori>>j)&1 == 1: ans.append(pow(2,j)) break else: A += beki ans.append(beki) print(len(ans)) print(*ans) #print(sum(ans))