VJ数论专题AC代码临时保存

我的梦境 提交于 2020-02-05 11:55:47
//A
#include<bits/stdc++.h>

using namespace std;

bool vis[1000010];

void Get_Prime()
{
    int n = 1000010;
    int m = sqrt(n+0.5);
    memset(vis,0,sizeof(vis));
    for(int i=2; i<=m; i++) if(!vis[i])
        for(int j=i*i; j<=n; j+=i) vis[j] = 1;
    return ;
}

int Find(int n)
{
    for(int i=n+1; ; i++)
       if(!vis[i]) return i;
}

int main()
{
    Get_Prime();
    int t,n,x;
    long long sum;
    scanf("%d",&t);
    for(int i=1; i<=t; i++)
    {
        scanf("%d",&n);
        sum = 0;
        while(n--)
        {
            scanf("%d",&x);
            sum += Find(x);
        }
        printf("Case %d: %lld Xukha\n",i,sum);
    }
    return 0;
}
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!