码迷,mamicode.com
首页 > 其他好文 > 详细

dfs(三)填数问题

时间:2017-10-25 21:42:50      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:序列   water   []   ast   多少   个数   name   jsb   dfs   

 

标题:六角填数 

  
    如图【1.png】所示六角形中,填入1~12的数字。使得每条直线上的数字之和都相同。

    图中,已经替你填好了3个数字,请你计算星号位置所代表的数字是多少?

技术分享技术分享

#include <iostream>
#include<cstdio>
using namespace std;
int a[13] = {0},v[13] = {0};
void juge()
{
    int b[6];
    b[0]=a[1]+a[3]+a[6]+a[8];
    b[1]=a[1]+a[4]+a[7]+a[11];
    b[2]=a[2]+a[3]+a[4]+a[5];
    b[3]=a[2]+a[6]+a[9]+a[12];
    b[4]=a[5]+a[7]+a[10]+a[12];
    b[5]=a[8]+a[9]+a[10]+a[11];
    for(int i = 1;i < 6; i++)
    {
        if(b[i] != b[i-1])
            return;
    }
     printf("%d\n",a[6]);
}
void dfs(int x)
{
   if(x == 1 || x == 2 || x == 12)
   {
       dfs(x+1);
       return;
   }
   if(x == 13)
   {
       juge();
   }
   for(int i = 1;i < 13;i++)
   {
       if(v[i] == 0){
           v[i] = 1;
           a[x] = i;
           dfs(x + 1);
           v[i] = 0;
       }
   }
}

int main()
{
    a[1] = 1;
    a[2] = 8;
    a[12] = 3;
    v[1] = 1;
    v[8] = 1;
    v[3] = 1;
    dfs(1);
    return 0;
}

采用v[]来标记已经经过的位置,给每个位置都排好序列。然后采用“固定”的dfs格式去写。

dfs(三)填数问题

标签:序列   water   []   ast   多少   个数   name   jsb   dfs   

原文地址:http://www.cnblogs.com/yanmengdi/p/7731690.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!