結果

問題 No.12 限定された素数
ユーザー mh72012246mh72012246
提出日時 2016-11-15 18:35:09
言語 C++11
(gcc 13.3.0)
結果
AC  
実行時間 163 ms / 5,000 ms
コード長 2,214 bytes
コンパイル時間 1,022 ms
コンパイル使用メモリ 87,420 KB
実行使用メモリ 26,676 KB
最終ジャッジ日時 2024-11-24 09:00:16
合計ジャッジ時間 5,627 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 155 ms
26,540 KB
testcase_01 AC 157 ms
26,464 KB
testcase_02 AC 159 ms
26,544 KB
testcase_03 AC 144 ms
24,652 KB
testcase_04 AC 162 ms
26,676 KB
testcase_05 AC 158 ms
26,668 KB
testcase_06 AC 154 ms
26,548 KB
testcase_07 AC 153 ms
25,648 KB
testcase_08 AC 157 ms
26,540 KB
testcase_09 AC 163 ms
26,672 KB
testcase_10 AC 160 ms
26,668 KB
testcase_11 AC 143 ms
25,404 KB
testcase_12 AC 152 ms
25,648 KB
testcase_13 AC 159 ms
26,676 KB
testcase_14 AC 156 ms
26,672 KB
testcase_15 AC 159 ms
26,672 KB
testcase_16 AC 149 ms
25,648 KB
testcase_17 AC 151 ms
26,668 KB
testcase_18 AC 153 ms
26,460 KB
testcase_19 AC 150 ms
26,544 KB
testcase_20 AC 155 ms
26,548 KB
testcase_21 AC 161 ms
26,548 KB
testcase_22 AC 155 ms
26,544 KB
testcase_23 AC 153 ms
26,668 KB
testcase_24 AC 157 ms
26,544 KB
testcase_25 AC 157 ms
26,672 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <cmath>
#include <vector>
// #include <array>
#include <queue>
#include <set>
#include <map>
#include <sstream>   // istringstream
#include <algorithm> // sort
#include <utility>   // pair
#include <cfloat>    // DBL_MAX

typedef long long ll;
using namespace std;

const int maxR = 5000000;
bool ps[maxR-1]; // 2~maxN-1 : 0~maxN-3
//bool ov[maxR-1]; // 2~maxN-1 : 0~maxN-3

bool match(vector<int> tgtAs, vector<int> dCount){
  for(uint i=0; i<tgtAs.size(); i++){
    if(dCount[tgtAs[i]] == 0){
      return false; // didn't appears
    }
  }
  return true;
}

int main(){
  // prime
  ll L=1, R=maxR;
  map<int,int> p2i;
  //vector<int> primes;
  for(int i=0; i<R-1; i++){ ps[i] = true; }
  for(int i=2; i*i<R; i++){
    if(ps[i-2]){
      for(int j=i*i; j<=R; j+=i){
        ps[j-2] = false;
      }
    }
  }
  int count = 0;
  for(int i=L; i<=R; i++){
    if(ps[i-2]){
      p2i[i] = count++;
      //primes.push_back(i);
    }
  }
  // int np = primes.size();
  // cout << np << endl;

  // input
  ll N; // [10]
  cin >> N;
  vector<int> As(N);
  vector<bool> appear(10,false);
  for(int i=0; i<N; i++){
    cin >> As[i];
  }
  for(int i=0; i<N; i++){
    appear[As[i]] = true;
  }

  // clc excessness
  // for(int i=0; i<R-1; i++){ ov[i] = false; }

  vector<int> excess;
  excess.push_back(0);
  for(int i=0; i<maxR; i++){
    if(!ps[i-2]){ continue; }
    int crr = i;
    while(crr>0){
      if(!appear[crr%10]){
        excess.push_back(i);
        break;
      }
      crr /= 10;
    }
  }
  excess.push_back(maxR+1);

  // for(int i=0; i<100; i++){
  //   if(ps[i-2]){
  //     cout << i << " ";
  //   }
  // } cout << endl;
  // for(int i=0; i<30; i++){
  //   cout << excess[i] << " ";
  // } cout << endl;

  // main
  // shakutori -> xx
  // *x-*-*---xx---...
  //   i     j

  int maxI = -1;
  for(uint i=0; i<excess.size()-1; i++){
    vector<int> dCount(10,0);
    for(int j=excess[i]+1; j<excess[i+1]; j++){
      if(!ps[j-2]){ continue; }
      int crr = j;
      while(crr>0){
        dCount[crr%10]++;
        crr/=10;
      }
    }
    if(match(As, dCount)){
      maxI = max(maxI, excess[i+1]-excess[i]-2);
    }
  }

  cout << maxI << endl;

  return 0;
}
0