C语言及程序设计进阶例程-26 回溯溯法问题求解
来源:互联网 发布:东华软件 薛向东 编辑:程序博客网 时间:2024/05/16 08:39
贺老师教学链接 C语言及程序设计进阶 本课讲解
8皇后问题实现代码
#include <stdio.h>#include <math.h>#include <malloc.h>void nQueens(int *x, int n); /*求解n皇后问题*/int place(int *x, int k); /*判断是否可以在第k行第x[k]列摆放皇后*/void printSolution(int *x, int n); /*输出求解结果*/int main(){ int n; int *x; /*存放求解结果的数组首地址*/ scanf("%d", &n); x=(int*)malloc(sizeof(int)*(n+1)); /*动态分配数组空间, x[0]空闲*/ nQueens(x, n); return 0;}/*如果一个皇后能放在第k行第x[k]列,则返回真(1),否则返回假(0)*/int place(int *x, int k){ int i; /*对前k-1行,逐行考察*/ for(i=1; i<k; i++) { /*如果前k-1行中有某行的皇后与第k行的在同一列或同一斜线,返回0*/ if((x[i]==x[k])||(fabs(x[i]-x[k])==fabs(i-k))) return 0; } /*能执行下一句,说明在第k行第x[k]列摆放皇后,不会互相攻击*/ return 1;}/*求解在n×n的棋盘上,放置n个皇后,使其不能互相攻击*/void nQueens(int *x, int n){ int k; k = 1; /*k是当前行*/ x[k] = 0; /*x[k]是当前列,进到循环中,立刻就会执行x[k]++,而选择了第1列*/ while(k>0) /*由后面的回溯步k--,当将所有可能的解尝试完后,k将变为0,结束求解过程*/ { x[k]++; /*移到下一列*/ while(x[k]<=n && !place(x, k)) /*逐列考察,找出能摆放皇后的列x[k]*/ x[k]++; if(x[k]<=n) /*找到一个位置可以摆放皇后*/ { if(k==n) /*是一个完整的解,输出解*/ printSolution(x, n); else /*没有完成最后一行的选择,是部分解,转向下一行*/ { k++; /*接着考察下一行*/ x[k]=0; /*到循环开始执行x[k]++后,下一行将从第1列开始考察*/ } } else /*对应x[k]>n的情形,这一行已经没有再试的必要,回溯到上一行*/ k--; /*到循环开始执行x[k]++后,上一行在原第x[k]列的下1列开始考察*/ }}/*输出求解结果*/void printSolution(int *x, int n){ int i, j; for (i = 1; i <= n; i++) /*输出第i行*/ { for (j=1; j<=n; j++) { if (j == x[i]) /*第x[i]列输出Q,其他列输出*号 */ printf("Q"); else printf("*"); } printf("\n"); } printf("\n");}
1 0
- C语言及程序设计进阶例程-26 回溯溯法问题求解
- C语言及程序设计进阶例程-6 递归法问题求解
- C语言及程序设计进阶例程-27 贪心法问题求解
- C语言及程序设计进阶例程-28 动态规划法问题求解
- C语言及程序设计进阶例程-24 查找问题及其求解
- C语言及程序设计进阶例程-25 排序问题及其求解
- C语言及程序设计初步例程-35 问题求解方法——迭代
- C语言及程序设计进阶例程-7 递归经典:汉诺塔
- C语言及程序设计进阶例程-5 认识递归
- C语言及程序设计进阶例程-11 体验结构体
- C语言及程序设计进阶例程-14 开发一个电子词典
- C语言及程序设计进阶例程-17 认识链表
- C语言及程序设计进阶例程-19 链表应用
- C语言及程序设计进阶例程-30 联合体及其应用
- C语言及程序设计进阶例程-37 二进制文件及其读写
- 第1周 C语言及程序设计初步 例程-7 问题求解方法——迭代
- C语言回溯法递归求解八皇后问题
- C语言及程序设计进阶例程-2 一个程序,多个文件
- 字符集和字符编码
- C语言及程序设计进阶例程-25 排序问题及其求解
- github代码提交(简单直接命令行方式)
- Python数据类型之数字类型、字符串类型
- web python -- WSGI接口GET请求
- C语言及程序设计进阶例程-26 回溯溯法问题求解
- 运行一个简单的C#程序
- windows访问虚拟机中的linux
- C语言及程序设计进阶例程-27 贪心法问题求解
- 2015062208 - 公交卡事件
- python相关面试题
- C语言及程序设计进阶例程-28 动态规划法问题求解
- 6月14日--6月22日(15小时,剩3715小时)
- poj 1742 Coins