結果
問題 |
No.6 使いものにならないハッシュ
|
ユーザー |
![]() |
提出日時 | 2020-11-07 22:16:41 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 7 ms / 5,000 ms |
コード長 | 776 bytes |
コンパイル時間 | 1,870 ms |
コンパイル使用メモリ | 175,820 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-16 16:59:32 |
合計ジャッジ時間 | 2,883 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge6 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 32 |
ソースコード
#include <bits/stdc++.h> using namespace std; int main(){ int K; cin >> K; int N; cin >> N; vector<bool> prime(N + 1, true); prime[0] = false; prime[1] = false; for (int i = 2; i <= N; i++){ if (prime[i]){ for (int j = i * 2; j <= N; j += i){ prime[j] = false; } } } vector<int> p; for (int i = K; i <= N; i++){ if (prime[i]){ p.push_back(i); } } int M = p.size(); int ans1 = 0; int ans2 = 0; for (int i = 0; i < M; i++){ set<int> st; for (int j = i; j < M; j++){ int h = (p[j] - 1) % 9 + 1; if (st.count(h)){ break; } st.insert(h); int d = j - i + 1; if (d >= ans1){ ans2 = p[i]; ans1 = d; } } } cout << ans2 << endl; }