Dominoes-第一个回溯

//回溯的应用,又是深搜,把符合条件的和不符合条件的都穷举出来,成树。
#include<stdio.h>
struct Node{
 int e;
 int s;
 int sign;
};
int c,n,si;
Node map[11];
void dfs(int k)//k是元组末的尾(元素列的最后一个元素的)。
{
 int i;
 if(c==n&&k==map[0].s){
  si=1;
  return ;//符合条件的那一个
 }
 else{
  for(i=0;i<n;i++)
   if(map[i].sign!=1){
    if(map[i].s==k){
     c++;
     map[i].sign=1;
     dfs(map[i].e);
     c--;        //回溯时要还原计数及标志。
     map[i].sign=0;
    }
    if(map[i].e==k){
     c++;
     map[i].sign=1;
     dfs(map[i].s);
     c--;
     map[i].sign=0;
    }

   }
 }
}


main()
{
 int i;
 int ca=0;
 while(ca++,scanf("%d",&n),n){
  si=0;
  c=1;
  for(i=0;i<n;i++){
   scanf("%d%d",&map[i].s,&map[i].e);
   map[i].sign=0;
  }
  map[0].sign=1;
  dfs(map[0].e);
  if(si==1)printf("Set #%d: YES/n",ca);
  else printf("Set #%d: NO/n",ca);
 }
 return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值