大致题意:每个多米诺骨牌可能横着,也可能竖着,请你判断有哪些合法的摆放方式。

这题的dfs需要注意一下,不能以某个点直接开始延伸,如果这样延伸可能会无法到达终点(也就是遍历全图)。我的dfs方法就是枚举每一行,一行枚举完了进入下一行。

AC代码:

#include<cstring>
#include<cstdio>
const int maxn=8;
int bone[maxn][maxn],pip[maxn][maxn],ans[maxn][maxn];
int vis[30];
int dx[]={0,1};
int dy[]={1,0};
void init(){
    int val=1;
    for(int i=0;i<=6;++i){
        for(int j=i;j<=6;++j)
            bone[i][j]=bone[j][i]=val++;
    }
}

int cnt=0;
void dfs(int d,int x,int y){
    if(d==28){
        cnt++;
        for(int i=0;i<7;++i){
            for(int j=0;j<8;++j){
                printf("  %2d",ans[i][j]);
            }
            printf("\n");
        }
        printf("\n\n");
        return;
    }
    if(y==8) {dfs(d,x+1,0);return;}
    if(ans[x][y]) {dfs(d,x,y+1);return;}
    for(int i=0;i<2;++i){
        int newx=x+dx[i],newy=y+dy[i];
        if(newx<0||newx>=7||newy<0||newy>=8) continue;
        if(ans[newx][newy]) continue;
        int v1=pip[x][y],v2=pip[newx][newy];
        int key=bone[v1][v2];
        if(vis[key]) continue;
        ans[x][y]=ans[newx][newy]=key;
        vis[key]=1;
        dfs(d+1,x,y+1);
        ans[x][y]=ans[newx][newy]=0;
        vis[key]=0;
    }
}

int main(){
    init();
    int e,kase=1;
    while(scanf("%d",&e)==1){
        if(kase>1) printf("\n\n\n");
        memset(vis,0,sizeof(vis));
        memset(ans,0,sizeof(ans));
        cnt=0;
        for(int i=0;i<7;++i)
        for(int j=0;j<8;++j){
            if(i==0&&j==0) pip[i][j]=e;
            else scanf("%d",&pip[i][j]);
        }

        printf("Layout #%d:\n\n\n",kase);
        for(int i=0;i<7;++i){
            for(int j=0;j<8;++j)
                printf("  %2d",pip[i][j]);
            printf("\n");
        }
        printf("\n");
        printf("Maps resulting from layout #%d are:\n\n\n",kase);
        dfs(0,0,0);
        printf("There are %d solution(s) for layout #%d.\n",cnt,kase++);
    }
    return 0;
}

如有不当之处欢迎指出!

uva211 回溯的更多相关文章

  1. N皇后问题—初级回溯

    N皇后问题,最基础的回溯问题之一,题意简单N*N的正方形格子上放置N个皇后,任意两个皇后不能出现在同一条直线或者斜线上,求不同N对应的解. 提要:N>13时,数量庞大,初级回溯只能保证在N< ...

  2. jQuery 2.0.3 源码分析 回溯魔法 end()和pushStack()

    了解了jQuery对DOM进行遍历背后的工作机制,可以在编写代码时有意识地避免一些不必要的重复操作,从而提升代码的性能 从这章开始慢慢插入jQuery内部一系列工具方法的实现 关于jQuery对象的包 ...

  3. linux中oops信息的调试及栈回溯【转】

    本文转载自:http://blog.csdn.net/kangear/article/details/8217329 ========================================= ...

  4. Java数据结构之回溯算法的递归应用迷宫的路径问题

    一.简介 回溯法的基本思想是:对一个包括有很多结点,每个结点有若干个搜索分支的问题,把原问题分解为对若干个子问题求解的算法.当搜索到某个结点.发现无法再继续搜索下去时,就让搜索过程回溯(即退回)到该结 ...

  5. 回溯 DFS 深度优先搜索[待更新]

      首先申明,本文根据微博博友 @JC向北 微博日志 整理得到,本文在这转载已经受作者授权!   1.概念   回溯算法 就是 如果这个节点不满足条件 (比如说已经被访问过了),就回到上一个节点尝试别 ...

  6. 46. Permutations 回溯算法

    https://leetcode.com/problems/permutations/ 求数列的所有排列组合.思路很清晰,将后面每一个元素依次同第一个元素交换,然后递归求接下来的(n-1)个元素的全排 ...

  7. Js杂谈-正则的测试与回溯次数

    例子来源于<精通正则表达式(第三版)>这本书,我贴出来: 这里的NFA是正则的一种引擎,书中介绍了一共三种引擎:NFA,DFA和POSIX NFA.像一般我们常用的.NET,java.ut ...

  8. SDUT 1400 马的走法(回溯法)

    题目链接: 传送门 马的走法 Time Limit: 1000MS     Memory Limit: 65536K 题目描述 在一个4*5的棋盘上,马的初始位置坐标(纵 横)位置由键盘输入,求马能返 ...

  9. ACM/ICPC 之 最长公共子序列计数及其回溯算法(51Nod-1006(最长公共子序列))

    这道题被51Nod定为基础题(这要求有点高啊),我感觉应该可以算作一级或者二级题目,主要原因不是动态规划的状态转移方程的问题,而是需要理解最后的回溯算法. 题目大意:找到两个字符串中最长的子序列,子序 ...

随机推荐

  1. 6_css选择器

    如何应用css样式? 找标签 写样式 如何找出标签? class选择器 .类名(注意前面点){ 样式 } .a{ color: green; } <p class="a"&g ...

  2. linux 中 ping的回传值

      今天在学习鸟哥私房菜的过程中,不明白ping的回传值是怎么设置的,后来网上找的结果了,特此记录一下 1 题目大意是指,ping一个网段的机器,如果可以通,就显示UP,如果不通就显示Down,其中一 ...

  3. linkin大话面向对象--枚举

    枚举类(enum) 其实我们使用到枚举的地方还是很多的,其实我们可以完全人工的来实现枚举的功能.比如说我现在手里的项目我就是自己实现的枚举,说白了,枚举就是一个类的多例模式. 1,使用enum声明,默 ...

  4. Linux常用命令(一)--系统命令

    命令字 命令字 [命令选项] [命令参数] 1. 命令中所有字符区分大小写 2. 命令选项分为短格式(-)及长格式(–) 3. 必须在命令行提示符下输入命令 4. 命令中的各个部分至少需要一个空格分隔 ...

  5. 嵌套for in循环组合cat方式文件中包含空格问题

    关于循环嵌套使用for循环的空格问题 原创不易,转载请注明 需求: 现有两个功文件,需要将文件拼接 [root@localhost ~]# cat name 111 222 223 333 444 5 ...

  6. zabbix监控-自定义监控与报警(二)

    标签: linux 笔者Q:972581034 交流群:605799367.有任何疑问可与笔者或加群交流 1.web界面操用(host groups) 1.1创建一个组名字为damo 1.2配置文件解 ...

  7. bootstrap select2 使用简单介绍

    1. 基本属性配置: $("#select2-id").select2({ templateResult : formatState, // 列表带图片 templateSelec ...

  8. Power shell 重启IIS

    最近根据项目需要写了一段power shell的代码 ,主要功能是批量重启IIS 具体的 Power shell 服务如下: write-output 'Restarting IIS servers ...

  9. ABP官方文档翻译 6.6 Javascript API

    JavaScript API AJAX 通知 消息 UI Block和Busy 事件总线 日志 其他实用功能 ABP提供了一套对象和函数,用来简化.标准化javascript的开发. 这里是ABP提供 ...

  10. ubuntu 新手入门第一天

    在虚拟机上安装好linux之后,当前版本 ubuntu-16.04.3-desktop-amd64.iso 1. 设置root用户名和密码 sudo passwd 然后输入两次密码 2. 设置软件源 ...