首页 > 其他 > 详细

1036选数

时间:2021-02-04 22:45:36      阅读:26      评论:0      收藏:0      [点我收藏+]

#include <bits/stdc++.h>

using namespace std;

int n=0,k=0,ans=0;

int a[25];

bool panduan(int x)

{

    for(int i=2;i<floor(sqrt(x));i++)

    {

        if(x%i==0)  return false;

    }

    return true;//别忘了

}

void fun(int start,int count,int sum)//功能单元为从start开始往后选一个数,count记录了选的深度,sum记录和

{

    if(count==k && panduan(sum))//递归深度限制为k

    {

        ans++;

    }

    for(int i=start;i<n;i++)

    {

        fun(i+1,count+1,sum+a[i]);

    }

}

int main()

{

    cin>>n>>k;

    for(int i=0;i<n;i++)

    {

        cin>>a[i];

    }

    fun(0,0,0);

    cout<<ans<<endl;

    return 0;

}

1036选数

原文:https://www.cnblogs.com/Hello-world-hello-lazy/p/14375036.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!