此题方法多种,我用规范的DFS来求解
题目:方格填数
如下的10个格子,填入0~9的数字。要求:连续的两个数字不能相邻。 
(左右、上下、对角都算相邻)一共有多少种可能的填数方案? 
 

输出

请填写表示方案数目的整数。 
 #include <iostream>
#include <vector>
#include <stdio.h>
#include <queue>
#include <cmath>
using namespace std;
const int ROW = ;
const int COL = ; int my[] = {};
int sum = ;
int num = ; int dd8[][] = {{-,},{,},{,},{,-},{-,},{,},{-,-},{,-}};
int dd[][] = {{-,},{,},{,},{,-}};
vector<vector<int> >sig[];
vector<vector<int> >matrix(ROW,vector<int>(COL,-)); bool check(int i,int j,int number){
if(my[number] == )
return false;
for(int zz = ;zz < ;zz++){
int ii = i + dd8[zz][];
int jj = j + dd8[zz][];
if(ii < ||jj < ||ii >= ROW||jj >= COL)
continue;
if(ii == &&jj ==)
continue;
if(ii == ROW - &&jj == COL - )
continue;
if(abs(matrix[ii][jj] - number) == )
return false;
}
return true;
}
void rightload(){
sig[sum] = matrix;
}
int checkrightload(){
for(int k = ;k < sum;k++){
if(sig[k] == matrix)
return ;
}
return ;
}
void lock(int i,int j,int k){
num--;
my[k] = ;
matrix[i][j] = k;
}
void unlock(int i,int j,int k){
num++;
my[k] = ;
matrix[i][j] = -;
}
void dfs(int i,int j){
for(int zz = ;zz < ;zz++){
int ii = i + dd[zz][];
int jj = j + dd[zz][];
if(ii < ||jj < ||ii >= ROW||jj >= COL)
continue;
if(ii == &&jj ==)
continue;
if(ii == ROW - &&jj == COL - )
continue;
if(matrix[ii][jj] == -){
for(int k = ;k < ;k++){
if(check(ii,jj,k) == true){
lock(ii,jj,k);
if(num == ){
if(checkrightload() == ){
rightload();
sum++;
}
unlock(ii,jj,k);
return;
}
else
dfs(ii,jj);
unlock(ii,jj,k); }
}
}
}
}
int main(){
for(int i = ;i < ;i++){
lock(,,i);
dfs(,);
unlock(,,i);
}
cout << sum <<endl;
return ;
}

DFS(深度优先搜索遍历求合格条件总数)--07--DFS--蓝桥杯方格填数的更多相关文章

  1. DFS+BFS(广度优先搜索弥补深度优先搜索遍历漏洞求合格条件总数)--09--DFS+BFS--蓝桥杯剪邮票

    题目描述 如下图, 有12张连在一起的12生肖的邮票.现在你要从中剪下5张来,要求必须是连着的.(仅仅连接一个角不算相连)  比如,下面两张图中,粉红色所示部分就是合格的剪取.  请你计算,一共有多少 ...

  2. 第七届 蓝桥杯 方格填数 dfs

    如下的10个格子  填入0~9的数字.要求:连续的两个数字不能相邻. (左右.上下.对角都算相邻) 一共有多少种可能的填数方案? 请填写表示方案数目的整数. 注意:你提交的应该是一个整数,不要填写任何 ...

  3. 蓝桥杯 方格填数 DFS 全排列 next_permutation用法

    如下的10个格子(参看[图1.jpg]) 填入0~9的数字.要求:连续的两个数字不能相邻.(左右.上下.对角都算相邻) 一共有多少种可能的填数方案? 请填写表示方案数目的整数.注意:你提交的应该是一个 ...

  4. 采用邻接矩阵表示图的深度优先搜索遍历(与深度优先搜索遍历连通图的递归算法仅仅是DFS的遍历方式变了)

    //采用邻接矩阵表示图的深度优先搜索遍历(与深度优先搜索遍历连通图的递归算法仅仅是DFS的遍历方式变了) #include <iostream> using namespace std; ...

  5. DFS(深度优先搜索遍历有向图)-03-有向图-太平洋大西洋水流问题

    给定一个 m x n 的非负整数矩阵来表示一片大陆上各个单元格的高度.“太平洋”处于大陆的左边界和上边界,而“大西洋”处于大陆的右边界和下边界. 规定水流只能按照上.下.左.右四个方向流动,且只能从高 ...

  6. 【算法导论】图的深度优先搜索遍历(DFS)

    关于图的存储在上一篇文章中已经讲述,在这里不在赘述.下面我们介绍图的深度优先搜索遍历(DFS). 深度优先搜索遍历实在访问了顶点vi后,访问vi的一个邻接点vj:访问vj之后,又访问vj的一个邻接点, ...

  7. 回溯算法 DFS深度优先搜索 (递归与非递归实现)

    回溯法是一种选优搜索法(试探法),被称为通用的解题方法,这种方法适用于解一些组合数相当大的问题.通过剪枝(约束+限界)可以大幅减少解决问题的计算量(搜索量). 基本思想 将n元问题P的状态空间E表示成 ...

  8. HDU 1241 Oil Deposits DFS(深度优先搜索) 和 BFS(广度优先搜索)

    Oil Deposits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...

  9. HDU 4707 Pet(DFS(深度优先搜索)+BFS(广度优先搜索))

    Pet Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissio ...

随机推荐

  1. SpringBoot 集成FreeMarker

    SpringBoot官方不推荐使用jsp,因为jsp不好发挥SpringBoot的特性.官方推荐使用模板引擎代替jsp,现在很多公司都使用FreeMarker来作为SpringBoot的视图. Spr ...

  2. Autoit里用多进程模拟多线程

      一直以来Autoit都不支持多线程,因此一些需要同时运行多个循环的操作也就无法实现.这个问题在其它的某些语言里也经常出现,解决的方法就是使用多进程. 所谓多进程,就是同时运行多个子进程,每个子进程 ...

  3. request DELETE 请求

    Django对于PUT/DELETE请求并没有像POST/GET那样有一个字典结构.我们需要手动处理request.body获取参数: 第一种方式: ujson.loads(request.body. ...

  4. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 表格:表示成功的操作

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  5. SqlSession为什么可以提交事务

    本应在开始读MyBatis源码时首先应该了解下MyBatis的SqlSession的四大对象:Executor.StatemenHandler.ParameterHandler.ResultHandl ...

  6. ionic3记录之栅格布局使文字居中

    { display:flex; align-items:center; } 未完待续...

  7. ch6 列表和导航条

    为列表添加定制的项目符号 可使用list-style-image属性:缺点是对项目符号图像的位置的控制能力不强. 常用的方法:使用list-style-type来关闭项目符号,将定制的项目符号作为背景 ...

  8. P1064 朋友数

    P1064 朋友数 转跳点:

  9. Ubuntu下安装 Mysql

    MYSQL在ubuntu16.04下的编译安装mysql-5.6.23.tar.gz 为减少安装过程中因权限带来个各种问题,建议全程用root用户编译安装,步骤如下: 1.安装依赖文件  apt-ge ...

  10. python 字典复制(存疑)

    import copy x = {'a':1,'b':[2,3,4]} y = x.copy() z = copy.deepcopy(x) print(x) print(y) print(z) pri ...