結果
問題 |
No.1531 く2
|
ユーザー |
![]() |
提出日時 | 2021-06-04 21:02:56 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 622 bytes |
コンパイル時間 | 1,740 ms |
コンパイル使用メモリ | 171,728 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-11-19 10:57:56 |
合計ジャッジ時間 | 3,325 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | WA * 4 |
other | WA * 44 |
ソースコード
#include <bits/stdc++.h> using namespace std; const int LOG = 61; const long long MOD = 998244353; long long f(long long N){ vector<vector<long long>> dp(LOG + 1, vector<long long>(2, 0)); dp[0][LOG] = 1; for (int i = LOG - 1; i >= 0; i--){ int d = N >> i & 1; if (d == 0){ dp[i][0] += dp[i + 1][0]; dp[i][1] += dp[i + 1][1] * 3; } else { dp[i][0] += dp[i + 1][0] * 2; dp[i][1] += dp[i + 1][0] + dp[i + 1][1] * 3; } dp[i][0] %= MOD; dp[i][1] %= MOD; } return dp[0][1]; } int main(){ long long N, K; cin >> N >> K; cout << (f(N + K + 1) - f(K) + MOD) % MOD; }