結果
問題 |
No.2300 Substring OR Sum
|
ユーザー |
👑 |
提出日時 | 2023-04-29 15:46:24 |
言語 | C (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 53 ms / 2,000 ms |
コード長 | 479 bytes |
コンパイル時間 | 961 ms |
コンパイル使用メモリ | 28,416 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-28 16:33:30 |
合計ジャッジ時間 | 2,306 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 20 |
ソースコード
#include <stdio.h> int main() { int i, N, A[200001]; scanf("%d", &N); for (i = 1; i <= N; i++) scanf("%d", &(A[i])); int j, k; long long ans = 0, num; for (k = 1; k < (1 << 28); k <<= 1) { num = (long long)N * (N + 1) / 2; for (i = 1, j = 0; i <= N; i++) { if ((A[i] & k) == 0) j++; else { num -= (long long)j * (j + 1) / 2; j = 0; } } num -= (long long)j * (j + 1) / 2; ans += num * k; } printf("%lld\n", ans); fflush(stdout); return 0; }