留着备用。

题目描述和代码参考:https://www.geeksforgeeks.org/8-queen-problem/

NQueenProblem(js代码):

class NQueenProblem {
static printSolution(board, numOfSolutions) {
console.log(`第${numOfSolutions}种解法:`);
for (let i = 0; i != board.length; ++i) {
let temp = "";
for (let j = 0; j != board.length; ++j) {
temp += board[i][j] + " ";
}
console.log(temp);
}
} static solve(num) {
let numOfSolutions = 0;
let board = CommonUtil.zeros(num, num); let isSafe = function(col, row) {
// 检查该行左边有没皇后
for (let i = 0; i != col; ++i) {
if (board[i][row] == 1) return false;
}
// 检查左上角
for (let i = col - 1, j = row - 1; i >= 0 && j >= 0; --i, --j) {
if (board[i][j] == 1) return false;
}
// 检查左下角
for (let i = col - 1, j = row + 1; i >= 0 && j < num; --i, ++j) {
if (board[i][j] == 1) return false;
}
return true;
}; let placeNextQueen = function(col) {
// 如果所有皇后都放置好了,说明找到了一种方案
if (col >= num) {
NQueenProblem.printSolution(board, ++numOfSolutions);
return;
} // 在可以放的地方试探
for (let i = 0; i != num; ++i) {
if (isSafe(col, i)) {
board[col][i] = 1;
placeNextQueen(col + 1);
board[col][i] = 0;
}
}
}; placeNextQueen(0);
} static run(data) {
NQueenProblem.solve(Number(data));
// Number(data)指的是皇后的数量
}
}

/

mColoringProblem(js代码):

class mColoringProblem {
static printSolution(colorOfPoint, numOfSolutions) {
console.log(`第${numOfSolutions}种解法:`);
console.log(colorOfPoint);
// 例如输出[1, 2, 3, 4, 1],表示第1个点第1种颜色,
// 表示第2个点第2种颜色,表示第3个点第3种颜色,
// 表示第4个点第4种颜色,表示第5个点第1种颜色,
} static solve(graph, m) {
let numOfSolutions = 0;
let colorOfPoint = graph.map(() => 0); // 存储每个点的着色情况 let isSafe = function(pointId, colorId) {
// 检查会不会和相邻的已着色点冲突
for (let i = 0; i != pointId; ++i) {
if (graph[pointId][i] == 1 && colorId == colorOfPoint[i]) {
return false;
}
}
return true;
}; let coloringNext = function(pointId) {
// 如果所有点都已经着色,说明找到了一种方案
if (pointId >= graph.length) {
mColoringProblem.printSolution(colorOfPoint, ++numOfSolutions);
return;
} // 尝试着色
for (let i = 1; i <= m; ++i) {
if (isSafe(pointId, i)) {
colorOfPoint[pointId] = i;
coloringNext(pointId + 1);
colorOfPoint[pointId] = 0;
}
}
}; coloringNext(0);
} static run(data) {
// 输入格式:首个数字表示着色点个数
// 之后是一个描述无向图的邻接矩阵,
// 最后是颜色数量
data = CommonUtil.handleData(data);
let num = data[0];
let graph = CommonUtil.zeros(num, num);
let k = 0;
for (let i = 0; i != num; ++i) {
for (let j = 0; j != num; ++j) {
graph[i][j] = data[++k];
}
}
let m = data[k + 1]; // console.log(num, graph, m);
mColoringProblem.solve(graph, m);
}
}

算法笔记 #007# Backtracking的更多相关文章

  1. 学习Java 以及对几大基本排序算法(对算法笔记书的研究)的一些学习总结(Java对算法的实现持续更新中)

    Java排序一,冒泡排序! 刚刚开始学习Java,但是比较有兴趣研究算法.最近看了一本算法笔记,刚开始只是打算随便看看,但是发现这本书非常不错,尤其是对排序算法,以及哈希函数的一些解释,让我非常的感兴 ...

  2. 算法笔记--数位dp

    算法笔记 这个博客写的不错:http://blog.csdn.net/wust_zzwh/article/details/52100392 数位dp的精髓是不同情况下sta变量的设置. 模板: ]; ...

  3. 算法笔记--lca倍增算法

    算法笔记 模板: vector<int>g[N]; vector<int>edge[N]; ][N]; int deep[N]; int h[N]; void dfs(int ...

  4. 算法笔记--STL中的各种遍历及查找(待增)

    算法笔记 map: map<string,int> m; map<string,int>::iterator it;//auto it it = m.begin(); whil ...

  5. 算法笔记--priority_queue

    算法笔记 priority_queue<int>que;//默认大顶堆 或者写作:priority_queue<int,vector<int>,less<int&g ...

  6. 算法笔记--sg函数详解及其模板

    算法笔记 参考资料:https://wenku.baidu.com/view/25540742a8956bec0975e3a8.html sg函数大神详解:http://blog.csdn.net/l ...

  7. 算法笔记——C/C++语言基础篇(已完结)

    开始系统学习算法,希望自己能够坚持下去,期间会把常用到的算法写进此博客,便于以后复习,同时希望能够给初学者提供一定的帮助,手敲难免存在错误,欢迎评论指正,共同学习.博客也可能会引用别人写的代码,如有引 ...

  8. 算法笔记_067:蓝桥杯练习 算法训练 安慰奶牛(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 Farmer John变得非常懒,他不想再继续维护供奶牛之间供通行的道路.道路被用来连接N个牧场,牧场被连续地编号为1到N.每一个牧场都是 ...

  9. 算法笔记(c++)--回文

    算法笔记(c++)--回文 #include<iostream> #include<algorithm> #include<vector> using namesp ...

随机推荐

  1. javascript 及 vue 中的变量前面的美元符号 $ 是什么意思

    $ 您会注意到,我们将库代理为以美元符号“$”为前缀的属性名. 你可能还看过其他的属性和方法,例如,$refs, $on, $mount等等也都是以”$”开头. 虽然属性名上添加前缀不是必须的,但是这 ...

  2. 【LeetCode每天一题】Merge Two Sorted Lists(合并两个排序链表)

    Merge two sorted linked lists and return it as a new list. The new list should be made by splicing t ...

  3. jenkins 常用插件和配置项介绍和使用

    jenkins 上搜索不到的插件可以在如下地址下载: http://updates.jenkins-ci.org/download/plugins/ 1.Notification Plugin 介绍: ...

  4. java的输入输出

    import java.util.Scanner; public class TestScanner { public static void main(String[] args) { Scanne ...

  5. sqlmap常用技巧整理

    言 通过在乌云网上出现的很多SQL注入漏洞,因此来总结一下,大致使用SQLMAP所遇到的参数. 基本结构 基本SQLMAP的使用方式就如下所示,使用参数式的方式,按需求添加. 12 sqlmap.py ...

  6. es6正则表达式

    es6中如果RegExp构造函数第一个参数是一个正则对象,那么可以使用第二个参数指定修饰符. 而且,返回的正则表达式会忽略原有的正则表达式的修饰符,只使用新指定的修饰符. new RegExp(/ab ...

  7. EL语言表达式 (三)【EL中的算术运算以及判断EL对象是否为空】

    一.EL中的算术运算 EL和其他语言一样,同样也提供了基本的算术运算(加.减.乘.除和取余),如下图. 运算符 功能 示例 结果 + 加 ${19+1} 20 - 减 ${66-30} 36 * 乘 ...

  8. java基础 逻辑

    1, 用for循环打印一个4*5的矩形 public class Test { public static void main(String[] args){ for (int i = 1; i &l ...

  9. 水题C

    某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……,L,都种有一棵树. ...

  10. Python全栈-day6-day7-字符编码和文件处理

    一.字符编码 1.编码基础 定义:人在使用计算机时,使用的是人类能够读懂的字符,使用者必须通过一张字符和数字间的相对应关系表实现人机交互,这一系列标准称为字符编码 Python应用中解决核心字符串乱码 ...