C语言-回溯例1
回溯法解N皇后问题
1,代码分析:
使用一个一维数组表示皇后的位置
其中数组的下标表示皇后所在的行
数组元素的值表示皇后所在的列
这样设计的棋盘,所有皇后必定不在同一行
假设前n-1行的皇后已经按照规则排列好
那么可以使用回溯法逐个试出第n行皇后的合法位置
所有皇后的初始位置都是第1列
那么逐个尝试就是从1试到N
如果当前行的皇后的位置还是在1到N的合法范围内
那么首先要判断该行的皇后是否与前几行的皇后互相冲突
如果冲突,该行的皇后的位置加1,继续尝试
如果不冲突,判断下一行的皇后
如果已经是最后一行,说明已经找到一个解,输出这个解
然后最后一行的皇后的位置加1,继续尝试下一个解
2,代码实现:
/**************x皇后问题***************/
#include <stdio.h>
#define N 4//自定义皇后的个数
int myabs(int a,int b)
{
return a>b?(a-b):(b-a);
}
int main()
{
int i,j,num,a[];
int k;
int flag;//设置标志位,用来判断是否满足约束条件
i=;
a[]=;//设初值
num=;//记录解得个数
while()
{
flag=;
for(k=i-;k>=;k--)
{
if((a[k]==a[i])||myabs(a[k],a[i])==(i-k))//满足约束条件
flag =;//改变标志位,表示不满足条件
}
if(flag&&(i==N))//输出一组解
{
num++;
for(j=;j<=N;j++)
{
printf("%d",a[j]);
}
printf(" ");
if((num%)==)
{
printf("\n");
}
}
if(flag&&i<=N)
{
i++;
a[i]=;//取初值
continue;
}
while(a[i]==N&&i>)i--;//回溯
if(a[i]==N&&i==)
{
break;
}
else
{
a[i]++;//改变另一条路径
}
}
printf("\n解得个数为%d",num);
return ;
}
运行结果:

3,代码实现:
/**************x皇后问题***************/
#include <stdio.h>
#define N 8//自定义皇后的个数
int myabs(int a,int b)
{
return a>b?(a-b):(b-a);
}
int main()
{
int i,j,num,a[];
int k;
int flag;//设置标志位,用来判断是否满足约束条件
i=;
a[]=;//设初值
num=;//记录解得个数
while()
{
flag=;
for(k=i-;k>=;k--)
{
if((a[k]==a[i])||myabs(a[k],a[i])==(i-k))//满足约束条件
flag =;//改变标志位,表示不满足条件
}
if(flag&&(i==N))//输出一组解
{
num++;
for(j=;j<=N;j++)
{
printf("%d",a[j]);
}
printf(" ");
if((num%)==)
{
printf("\n");
}
}
if(flag&&i<=N)
{
i++;
a[i]=;//取初值
continue;
}
while(a[i]==N&&i>)i--;//回溯
if(a[i]==N&&i==)
{
break;
}
else
{
a[i]++;//改变另一条路径
}
}
printf("\n解得个数为%d",num);
return ;
}
运行结果:

C语言-回溯例1的更多相关文章
- C语言-回溯例4
1,问题提出 日本数学家桥本吉彦教授于1993年10月在我国山东举行的中日美三国数学教育研讨会上向与会者提出以下填数趣题: 把1,2,...,9这9个数字填入下式的九个方格中(数字不得重复),使下面 ...
- C语言-回溯例3
排列问题 1.实现排列A(n,m)对指定的正整数m,n(约定1<m<=n),具体实现排列A(n,m).2. 回溯算法设计设置一维数组a,a(i)(i=1,2,…,m)在1—n中取值.首先从 ...
- C语言-回溯例2
组合问题 组合:从n个不同元素中取r个不重复的元素组成一个子集,而不考虑其元素的顺序,称为从n个中取r个的无重组合,例如OR = {1,2,3,4}, n = 4, r = 3则无重组合为: {1,2 ...
- C语言 指针例解
在计算机科学中,指针(Pointer)是编程语言中的一个对象,利用地址,它的值直接指向(points to)存在电脑存储器中另一个地方的值.由于通过地址能找到所需的变量单元,可以说,地址指向该变量单元 ...
- Python语言100例
Python版本:python 3.2.2 电脑系统:win7旗舰 实例来源:python菜鸟教程100例 #!/usr/bin/python # -*- coding: UTF-8 -*- impo ...
- C语言回溯算法解决N皇后问题
回溯算法的模型是 x++, not satisfy ? x-- : continue. 代码中x作列号,y[x]保存第x列上皇后放置的位置. #include<stdio.h> #incl ...
- 动态语言的灵活性是把双刃剑 -- 以Python语言为例
本文有些零碎,总题来说,包括两个问题:(1)可变对象(最常见的是list dict)被意外修改的问题,(2)对参数(parameter)的检查问题.这两个问题,本质都是因为动态语言(动态类型语言)的特 ...
- 以C语言为例的程序性能优化 --《深入理解计算机系统》第五章读书笔记
其实大多数的编译器本身就能提供一些简单的优化,比如gcc就能通过使用 -O2 或者 -O3 的选项来优化程序.但编译器的优化始终也是有限,因为它必须小心翼翼保证优化过程不对程序的功能有改动.故而程序员 ...
- 浮点数运算的精度问题:以js语言为例
在 JavaScript 中整数和浮点数都属于 Number 数据类型,所有数字都是以 64 位浮点数形式储存,即便整数也是如此. 所以我们在打印 1.00 这样的浮点数的结果是 1 而非 1.00 ...
随机推荐
- PHPSTORM+Thinkphp3.2模板标签替换Thinkphp5.1公式
FORMAT: purpose: find: replace 替换<php>标签 <php>(.*)</php> {php}$1{/php} 替换<if &g ...
- java程序实现视频格式的转换
http://blog.sina.com.cn/s/blog_96b60b0c01013mi5.html 原文地址:java程序实现视频格式的转换作者:笑看风云 flv格式转换--第一步 不定期更新. ...
- [luoguP3231] [HNOI2013]消毒(最小点覆盖 + 状压)
传送门 考虑贪心,控制某一维为1,另两位最大是最优的,也就是一次选一个厚度为1的面 那么对于每个点,可以有3种面是可以选到它的 然后gg 考虑二维的状态,一个平面,有些点,一次选一行或一列最优 那么每 ...
- Static相关
[理解] 说到static,脑中浮现的几个Key Words是什么? main 类 唯一空间 所有对象共享 static只能处理static 很好,解释一下上面的意思: main static fie ...
- PAT 甲级 1003. Emergency (25)
1003. Emergency (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue As an emerg ...
- Object,String,StringBuffer,StringBuilder,System,Runtime,Date,Math介绍及用法(API)
1 Object对象 面向对象的核心思想:“找合适的对象,做适合的事情”. 合适的对象: 自己描述类,自己创建对象. sun已经描述了好多常用的类,可以使用这些类创建对象. API(App ...
- Linux Glibc幽灵漏洞紧急修补方案【转】
转自:http://blog.csdn.net/chen19870707/article/details/43560823 幽灵漏洞是Linux glibc库上出现的一个严重的安全问题,他可以让攻击者 ...
- jmeter登录禅道案例
下载jmeter,配置环境变量 变量名:JMETER_HOME 变量值:C:\Program Files\apache-jmeter-2.11 变量名:CLASSPATH 变量值:%JMETER_HO ...
- Linux 之 FTP服务器搭建
FTP服务器搭建 参考教程:[千峰教育] 1.关闭防火墙: service iptables stop 2.关闭Selinux setenforce 0 3.安装所需要依赖及编译工具 yum inst ...
- Yii命令行模式
(具体参数描述请使用命令看描述,不过全是英文) 1.Yii提供命令行指令不多,常用的有webapp 和 shell. 1. message 搜索指定文件信息 yicc message webroot ...