• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

2016年蓝桥杯省赛A组c++第3题(图论)

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
/*
有一个含有10个格子的图形,现用0~9填充,连续的数不能填充在相邻的格子中(包括对角线相邻)。
现每个数只能填写一次,问有多少种填充方法?
0111
1111
1110 
(1表示有格子,0表示没格子) 

解题思想:深度优先遍历即可
*/ 

#include<cstdio>  
#include<cstring>  
#include<algorithm>  
#include<iostream>  
#include<string>  
#include<vector>  
#include<stack>  
#include<bitset>  
#include<cstdlib>  
#include<cmath>  
#include<set>  
#include<list>  
#include<deque>  
#include<map>  
#include<queue>
using namespace std;

int t;  //t用于存放已经填写了的格子数目 
int flag[10];  //记录数字是否选  
int map[4][5];  //格子表 
int sum=0;  //sum为可行解的数目 

int judge()//判断已经填好的表是否符合要求  
{
    int i,j;  
    for(i=0;i<3;i++)  
    {  
        for(j=0;j<4;j++)  
            if(abs(map[i][j]-map[i][j+1])==1/*左右*/||abs(map[i][j]-map[i+1][j])==1/*上下*/||abs(map[i][j]-map[i+1][j-1])==1/*左上角*/||abs(map[i][j]-map[i+1][j+1])/*右上角*/==1)  
              return 0;  
    }  
    return 1;  
}  

//dfs函数用于填表  
void dfs(int t)  
{
    int i;  
    if(t==11)//t=11,即此时表中的10个格子全部填了数  
    {  
       if(judge())  sum++;
       return;  
    }  
    for(i=0;i<=9;i++)  
    {  
        if(!flag[i])  
        {  
            flag[i]=1;  
            map[t/4][t%4]=i;  
            dfs(t+1);  
            flag[i]=0;  //若递归返回,则说明该解不可行。回溯思想。 
        }  
    }  
}  

int main()  
{  
    int i;  
    for(i=0;i<4;i++)  
    {  
        map[i][4]=1000;  
    }  
    memset(flag,0,sizeof(flag));  //记号表归零 
    for(i=0;i<5;i++)  
        map[3][i]=1000;  //画表格图 
    map[0][0]=map[2][3]=1000;  
    dfs(1);  
    printf("%d\n",sum);  
    return 0;  
}

 

 

 

tz@COI HZAU

2018/3/15


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C++实现base64编码(1)发布时间:2022-07-14
下一篇:
使用VisualStudio2005IDE的宏,自动为c#变量生成属性发布时间:2022-07-14
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap