小编And*_*adu的帖子

如何以更有效的方式检查一个数是否为素数?

所以我有以下问题。他们给了我一个包含 n 个数字的数组,我必须使用“Divide et Impera”打印它是否包含任何素数。我解决了这个问题,但只得到了 70/100,因为它效率不高(他们说)。

#include <iostream>
using namespace std;

bool isPrime(int x){
   if(x == 2) return false;
   for(int i = 2; i <= x/2; ++i)
      if(x%i==0) return false;
   return true;

}

int existaP(int a[], int li, int ls){
    if(li==ls)
       if(isPrime(a[li]) == true) return 1;
       else return 0;
    else  return existaP(a, li, (li+ls)/2)+existaP(a, (li+ls)/2+1, ls);      
}

int main(){
   int n, a[10001];
   cin >> n;
   for(int i = 1; i<=n; ++i) cin >> a[i];
   if(existaP(a,1,n) >= 1) cout << "Y"; …
Run Code Online (Sandbox Code Playgroud)

c++ primes

3
推荐指数
1
解决办法
2万
查看次数

标签 统计

c++ ×1

primes ×1