回溯法解八皇后问题及再看八皇后问题优化

2024-03-27 10:32

本文主要是介绍回溯法解八皇后问题及再看八皇后问题优化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、介绍

先上张图来说明用回溯法解八皇后问题的每一步:

        


2、程序

看着严蔚敏的书写的,写好后运行一次性成功了,程序如下:

//  N皇后问题  #include <iostream>  
using namespace std;  #define N 8  bool matrix[N + 1][N + 1] = {0};  bool IsLegal(bool matrix[N + 1][N + 1], const int &i, const int &j)  
{  //  判断前面的i-1个棋子与matrix[i][j]是否冲突,i为1时合法  for (int m = 1; m <= i - 1; ++m) {  for (int n = 1; n <= N; ++n) {   //  实际每一行只有一个棋子  if (matrix[m][n] == 1) {  if ( n == j || abs(i - m) == abs(j - n) )   //  key, not bad  return false;  }  }  }  return true;  
}  void Print(bool matrix[N + 1][N + 1])  
{  static int count = 1;  printf("Case %d:\n", count++);  for (int i = 1; i <= N; i++) {  for (int j = 1; j <= N; j++) {  matrix[i][j] == 1 ? printf("%c ", 2) : printf(". ");  }  cout << endl;  }  cout << endl;  
}  void Trial(const int i)  
{  //  进入本函数时,在N*N的棋盘前i-1行已放置了互不攻击的i-1个棋子  //  现从第i行起继续为后续棋子选择合适位置  if (i > N)   //  输出当前的合法布局  Print(matrix);  else  for (int j = 1; j <= N; ++j) {  matrix[i][j] = 1;  if ( IsLegal(matrix, i, j) )  Trial(i + 1);  matrix[i][j] = 0;  }  
}  int main(void)  
{  Trial(1);  return 0;  
}  
运行结果:



3、数学问题

关于n皇后的解的个数(8皇后是92个解):

[cpp]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. n       a(n)  
  2. 1       1  
  3. 2       0  
  4. 3       0  
  5. 4       2  
  6. 5       10  
  7. 6       4  
  8. 7       40  
  9. 8       92  
  10. 9       352  
  11. 10      724  
  12. 11      2680  
  13. 12      14200  
  14. 13      73712  
  15. 14      365596  
  16. 15      2279184  
  17. 16      14772512  
  18. 17      95815104  
  19. 18      666090624  
  20. 19      4968057848  
  21. 20      39029188884  
  22. 21      314666222712  
  23. 22      2691008701644  
  24. 23      24233937684440  
  25. 24      227514171973736  
  26. 25      2207893435808352  
  27. 26      22317699616364044  

这篇关于回溯法解八皇后问题及再看八皇后问题优化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/851809

相关文章

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

MySQL中慢SQL优化的不同方式介绍

《MySQL中慢SQL优化的不同方式介绍》慢SQL的优化,主要从两个方面考虑,SQL语句本身的优化,以及数据库设计的优化,下面小编就来给大家介绍一下有哪些方式可以优化慢SQL吧... 目录避免不必要的列分页优化索引优化JOIN 的优化排序优化UNION 优化慢 SQL 的优化,主要从两个方面考虑,SQL 语

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错