1020

题目编号:1020

题目大意:你给1-N个数围成一圈,要求任意两数之和为质数而且第一个数为1,求这样的组合。(0<N<20)

解题思路:变形的深搜题。首先,判断素数,由于题目要求的数字不大,可以直接创建个一位数组,判断1-38中哪个是素数哪个不是,速度快而且简单。解决这道题目,往深搜一                     般写法靠近就行了,只是披上一层有点不一样的外衣罢了。先创建个数组,储存此数是否被访问过,再创建一个数组来存储结果。先输入数据,初始化,从1开始深搜                       函数。假如参数为N切合法也就是素数条件满足则结束,输出结果,否则进入循环,从第2个数字开始往结果后面排,然后判断,递归,还原。都是那一套深搜的一般步                   骤。

做题感想:题目千变万化,要有双看透本质的眼睛。

#include<iostream>
#include<cstring>
using namespace std;
int n,i,j,k,brr[21],arr[21],crr[38]={0,0,1,1,0,1,0,1,0,0,0,1,0,1,0,0,0,1,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,1};
void print(int n)
{
 for(k=1;k<n;k++)
         cout<<arr[k];
cout<<arr[n]<<endl;
}
void dfs(int num)
{
 if(num==n&&crr[arr[n]+arr[1]])
       print(n);
 else
 {
  for(j=2;j<=n;j++)
  {
   if(crr[arr[num]+j]&&brr[j]==0)
   {
               arr[num+1]=j;
               brr[j]=1;
               dfs(num+1);
               brr[j]=0;
           }
       }
   }
}
int  main()
{
 while(cin>>n&&n>0&&n<20)
 {
          i=1;
          memset(brr,0,sizeof(brr));
          cout<<"Case :"<<i++<<endl;
          arr[1]=1;
          brr[1]=1;
          dfs(1);
          cout<<endl;
                     }
          return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值