社区讨论

wa#1#4

P1036[NOIP 2002 普及组] 选数参与者 2已保存回复 4

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
4 条
当前快照
1 份
快照标识符
@lo152zth
此快照首次捕获于
2023/10/22 15:20
2 年前
此快照最后确认于
2023/11/02 14:52
2 年前
查看原帖
CPP
#include<bits/stdc++.h>

using namespace std;

bool isprime(int n)
{
    bool ret=true;
    for(int i=2;i<n;i++)
    {
        if(n%i==0)
        {
            ret=false;
        }
    }
    return ret;
}

int repeat(int n)
{
    double total=1;
    for(int i=2;i<=n;i++)
    {
        total*=i;
    }
    return total;
}

int main(){
    int n,k;
    cin>>n>>k;
    int arr[n];
    int counter=0,sum=0;
    for (int i=0;i<n;i++)
    {
        cin>>arr[i];
    }
    sort(arr,arr+n);

    do{
        sum=0;
		for (int i=0;i<k;i++)
        {
            sum+=arr[i];
        }
        if(isprime(sum))
        {
            counter++;
        }


	}while(next_permutation(arr,arr+n));
    cout<<counter/repeat(n-k)/repeat(k);

    return 0;
}
不知道错在哪里了

回复

4 条回复,欢迎继续交流。

正在加载回复...