#UVa:10533-Digit Primes

利用篩法將所要範圍內的質數找出,並在找出的時候順便算一下是否更進一步是 Digit Prime ,並且加總紀錄到該數之間 Digit Prime 的數量即可得解。

C++(0.190)

/*******************************************************/
/* UVa 10533 Digit Primes                              */
/* Author: Maplewing [at] knightzone.studio            */
/* Version: 2019/04/21                                 */
/*******************************************************/
#include <iostream>
#include <cstdio>
#include <vector>
using namespace std;

struct Number{
  bool isComposite;
  int totalDigitPrimeCount;
};

int bitSum(int number){
  int sum = 0;
  while(number > 0){
    sum += number % 10;
    number /= 10;
  }
  return sum;
}

int main(){
  const int TOTAL_NUMBER = 1000000;

  vector<Number> numbers(TOTAL_NUMBER, Number{false, 0});
  for(int i = 2; i < TOTAL_NUMBER ; ++i){
    if(numbers[i].isComposite){
      numbers[i].totalDigitPrimeCount = numbers[i-1].totalDigitPrimeCount;
      continue;
    }

    for(int j = i + i ; j < TOTAL_NUMBER ; j += i){
      numbers[j].isComposite = true;
    }

    numbers[i].totalDigitPrimeCount = numbers[i-1].totalDigitPrimeCount + 
      ((!numbers[bitSum(i)].isComposite)? 1 : 0);
  }

  int N;
  while(scanf("%d", &N) != EOF){
    for(int caseNumber = 1 ; caseNumber <= N ; ++caseNumber){
      int t1, t2;
      scanf("%d%d", &t1, &t2);
      printf("%d\n", numbers[t2].totalDigitPrimeCount - numbers[t1-1].totalDigitPrimeCount);
    }
  }
  return 0;
}

回應

目前無留言,歡迎留言!

發表迴響

這個網站採用 Akismet 服務減少垃圾留言。進一步瞭解 Akismet 如何處理網站訪客的留言資料

%d 位部落客按了讚: