社区讨论
DFS28分求调%%%
P1036[NOIP 2002 普及组] 选数参与者 2已保存回复 5
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 5 条
- 当前快照
- 1 份
- 快照标识符
- @mhj9qydv
- 此快照首次捕获于
- 2025/11/03 23:02 4 个月前
- 此快照最后确认于
- 2025/11/03 23:02 4 个月前
代码如下
CPP#include<bits/stdc++.h>
using namespace std;
int a[25],ans,st[25],n,p[25],cnt;
bool jud(int k)
{
if(k<=1)
return false;
else
{
for(int i=2;i*i<=k;i++)
{
if(k%i==0)
return false;
}
}
return true;
}
bool fin(int k)
{
for(int i=0;i<=cnt;i++)
{
if(k==p[i])
{
return false;
}
}
cnt++;
p[cnt]=k;
return true;
}
void dfs(int k,int b,int sum)//k,总层数,b,当前层数
{
if(b>k)
{
if(jud(sum)&&fin(sum))
{
ans++;
}
return ;
}
for(int i=1;i<=n;i++)
{
if(!st[i])
{
st[i]=1;
dfs(k,b+1,sum+a[i]);
st[i]=0;
}
}
}
int main()
{
int k;
cin>>n>>k;
for(int i=1;i<=n;i++)
{
cin>>a[i];
}
dfs(k,1,0);
cout<<ans;
return 0;
}
回复
共 5 条回复,欢迎继续交流。
正在加载回复...