結果
| 問題 |
No.1452 XOR×OR
|
| コンテスト | |
| ユーザー |
convexineq
|
| 提出日時 | 2021-04-01 10:49:18 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 42 ms / 2,000 ms |
| コード長 | 528 bytes |
| コンパイル時間 | 401 ms |
| コンパイル使用メモリ | 82,176 KB |
| 実行使用メモリ | 59,136 KB |
| 最終ジャッジ日時 | 2024-07-02 15:42:55 |
| 合計ジャッジ時間 | 2,763 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 36 |
ソースコード
def divisor_list(N): #約数のリスト
if N == 1: return [1]
res = []
for i in range(1,N):
if i*i >= N: break
if N%i == 0:
res.append(i)
res.append(N//i)
if i*i == N: res.append(i)
return sorted(res)
def f(a,b): #x^y = a, x|y = b?
ans = 1
while a or b:
p,q = a%2, b%2
if p==q==1: ans *= 2
if p==1 and q==0: ans = 0
a //= 2
b //= 2
return (1+ans)//2
n = int(input())
print(sum(f(i,n//i) for i in divisor_list(n)))
convexineq