結果
| 問題 | No.6 使いものにならないハッシュ | 
| コンテスト | |
| ユーザー |  Lay_ec | 
| 提出日時 | 2014-11-12 17:14:37 | 
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 8 ms / 5,000 ms | 
| コード長 | 1,213 bytes | 
| コンパイル時間 | 846 ms | 
| コンパイル使用メモリ | 84,680 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-09-16 16:21:59 | 
| 合計ジャッジ時間 | 1,702 ms | 
| ジャッジサーバーID (参考情報) | judge3 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 32 | 
ソースコード
#include <iostream> 
#include <string> 
#include <vector> 
#include <cmath> 
#include <algorithm> 
#include <cstdlib> 
#include <ctime> 
#include <cstdio> 
#include <functional> 
#include <set> 
#include <sstream> 
#include <cctype>
#include <queue>
using namespace std; 
typedef pair<int,int> pii;
const int INF=(1<<30);
int f(long x){
	int sum=0;
	while(x){
		sum+=x%10;
		x/=10;
	}
	if(sum<10) return sum;
	else return f(sum);
}
vector<long> get_Prime(long K,long N){
	vector<bool> prime(N+1,true);
	prime[0]=prime[1]=false;
	for(long i=2;i*i<=N;i++){
		if(prime[i]){
			for(int j=2;i*j<=N;j++) prime[i*j]=false;
		}
	}
	vector<long> res;
	for(long i=K;i<=N;i++) if(prime[i]) res.push_back(i);
	return res;
}
int main(){
	long K,N;
	cin>>K>>N;
	vector<long> prime=get_Prime(K,N);
	//[K,N]に素数が存在しない場合は...?
	long len=1,res=prime[0];
	for(int i=0;i<prime.size();i++){
		set<long> s;
		for(int j=i;j<prime.size();j++){
			int h=f(prime[j]);
			if(s.find(h)!=s.end()) break;
			else s.insert(h);
		}
		if(len<=s.size()){
			len=s.size();
			res=prime[i];
		}
	}
	cout<<res<<endl;
	return 0;
}
            
            
            
        