八皇后C++版本
emmmm~刚刚学C++,写一个八皇后,凑合看吧嘤嘤嘤
1 #include <iostream>
2 #include<cstdlib>
3 #include<cmath>
4
5 using namespace std;
6 int main()
7 {
8 int sz = 8;
9 int que[sz] = {0};
10 int i = 0;
11 while(i >= 0)
12 {
13 int k = 0;
14 while(k < i)
15 {
16 if(que[k] != que[i] && (abs(que[i] - que[k]) != abs(i - k)))
17 ++k;
18 else
19 break;
20 }
21
22 if(k < i)//出现冲突
23 {
24 ++que[i];
25
26 while(que[i] == sz)
27 {
28 que[i] = 0;
29 --i;
30
31 if(i < 0)
32 break;
33 ++que[i];
34 }
35 continue;
36 }
37
38 else
39 {
40 ++i;
41 if(i < sz)
42 continue;
43
44 cout << "找到一个方案";
45 for(k = 0;k < sz;++k)
46 cout << que[k];
47 cout << endl;
48
49 if(que[0] < sz-1)
50 {
51 ++que[0];
52 continue;
53 }
54 else
55 break;
56 }
57 }
58
59 return 0;
60 }
其实还是挺好明白的一个算法,叫——回溯法;
重点就在于:好多break和continue啥的跳来跳去——continue注意他的跳跃范围比较广
拿52行的continue说事:你感觉他会跳哪去?
答案就是11行(超远跳跃,你值得拥有)
————————————————————————————————————————————————————————————————————
第二波更新
详情请去做洛谷里面的八皇后
1 #include<iostream>
2 #include<cstdlib>
3 #include<cmath>
4 #include<cstdio>
5 using namespace std;
6 int a[100],b[100],c[100],d[100];
7 int total,n;
8
9 void print()
10 {
11 if(total <= 2)
12 {
13 for(int k = 1;k <= n;k++)
14 cout << a[k] << " ";
15
16 cout << endl;
17 }
18 total++;
19 }
20
21 void queen(int i)
22 {
23 if(i > n)
24 {
25 print();
26 return;
27 }
28
29 else
30 {
31 for(int j = 1;j <= n;j++)
32 {
33 if((!b[j]) && (!c[i + j]) && (!d[i - j + n]))
34 {
35 a[i] = j;
36 b[j] = 1;
37 c[i + j] = 1;
38 d[i - j + n] = 1;
39
40 queen(i + 1);
41 b[j] = 0;
42 c[i + j] = 0;
43 d[i - j + n] = 0;
44 }
45 }
46 }
47 }
48
49 int main()
50 {
51 cin >> n;
52 queen(1);
53 cout << total;
54 return 0;
55 }
这次更新的重点在于:queen()函数里面的return的作用
现阶段我能说的就是:return—>结束该层函数的运行返回递归调用函数的上层
举个例子:现在执行的是queen(7),但是发现所执行的方案无法满足要求,那就返回上一层也就是queen(6),更改相应的值,同时清除脏数据
八皇后C++版本的更多相关文章
- 八皇后算法的另一种实现(c#版本)
八皇后: 八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例.该问题是国际西洋棋棋手马克斯·贝瑟尔于1848年提出:在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于 ...
- C#八皇后问题 枚举值
记得刚出道的时候, 有考虑怎么面试, 以及可能会遇到的面试题, 有一个人说了一下 八皇后问题, 据说要用 sql 语句写出来, 暂时我 写了一个C#版本的, 经测验,八皇后算法结果为 92种, 这个与 ...
- Scheme来实现八皇后问题(2)
版权申明:本文为博主窗户(Colin Cai)原创,欢迎转帖.如要转贴,必须注明原文网址 http://www.cnblogs.com/Colin-Cai/p/9790466.html 作者:窗户 Q ...
- 八皇后问题的Python实现和C#实现
看到八皇后问题的解决思路, 感觉很喜欢. 我用C#实现的版本之前贴在了百度百科上(https://baike.baidu.com/item/%E5%85%AB%E7%9A%87%E5%90%8E%E9 ...
- [codeup] 2046 八皇后
题目描述 会下国际象棋的人都很清楚:皇后可以在横.竖.斜线上不限步数地吃掉其他棋子.如何将8个皇后放在棋盘上(有8 * 8个方格),使它们谁也不能被吃掉!这就是著名的八皇后问题. 对于某个满足要求的8 ...
- python基础教程总结8——特殊方法,属性,迭代器,生成器,八皇后问题
1. 重写一般方法和特殊的构造方法 1.1 如果一个方法在B类的一个实例中被调用(或一个属性被访问),但在B类中没有找到该方法,那么会去它的超类A里面找. class A: ... def hello ...
- 八皇后问题——列出所有的解,可推至N皇后
<数据结构>--邓俊辉版本 读书笔记 今天学习了回溯法,有两道习题,一道N皇后,一道迷宫寻径.今天,先解决N皇后问题.由于笔者 擅长java,所以用java重现了八皇后问题. 注意是jav ...
- 数据结构0103汉诺塔&八皇后
主要是从汉诺塔及八皇后问题体会递归算法. 汉诺塔: #include <stdio.h> void move(int n, char x,char y, char z){ if(1==n) ...
- Python学习二(生成器和八皇后算法)
看书看到迭代器和生成器了,一般的使用是没什么问题的,不过很多时候并不能用的很习惯 书中例举了经典的八皇后问题,作为一个程序员怎么能够放过做题的机会呢,于是乎先自己来一遍,于是有了下面这个ugly的代码 ...
随机推荐
- java 泛型学习随笔
对于java 泛型 编译时处理,运行时擦除的特点理解 对于编译时处理 在使用泛型相关的类或方法时,如果声明时的类型和具体使用时的类型不一致则直接会编译不通过 对于运行时擦除 当在运行时对两个相同类型但 ...
- 口罩预约管理系统——系统网站实现(前端+PHP+MySQL)
口罩预约管理系统网站实现 一.前言 二.系统登陆逻辑及界面实现 三.用户模块 1.用户预约系统界面 2.用户查看我的订单界面 3.用户修改预约信息 四.管理员模块 1.管理员登陆界面 2.查看用户预约 ...
- 关于properties文件的一些问题
在写properties文件时,比如jdbc.properties文件配置连接数据库的账号密码时,不要留有空格,不然会报错 com.mchange.v2.resourcepool.CannotAcqu ...
- 计算几何(一):凸包问题(Convex Hull)
引言 首先介绍下什么是凸包?如下图: 在一个二维坐标系中,有若干点杂乱排列着,将最外层的点连接起来构成的凸多边型,它能包含给定的所有的点,这个多边形就是凸包. 实际上可以理解为用一个橡皮筋包含住所有给 ...
- Python安装与环境变量配置 入门详解 - 精简归纳
Python安装与环境变量配置 入门详解 - 精简归纳 JERRY_Z. ~ 2020 / 9 / 24 转载请注明出处!️ 目录 Python安装与环境变量配置 入门详解 - 精简归纳 一.下载Py ...
- O、Θ、Ω
1.这些是时间复杂度的.(e.g. O(n).Θ(n).Ω(n)) 主要为主定理(坏东西) 2.本质 O <= Θ = Ω >=
- 《Java从入门到失业》第四章:类和对象(4.6):类路径
4.6类路径 4.6.1什么是类路径 前面我们讨论过包,知道字节码文件最终都会被放到和包名相匹配的树状结构子目录中.例如上一节的例子: 其实类还有一种存放方式,就是可以归档到一个jar文件中,jar文 ...
- cookie、session和md5加密
cookie Http无状态协议,只能在同一个网站(包括多个页面)下获取,存储在客户端本地的一段信息,帮助我们存储信息获取信息.但是同样有风险:我们自己在浏览器上可以操作或者设置Cookie. con ...
- 怎么摆脱又臭又长的 Git 命令?
在使用 Git 的时候,虽然大部分时候我们用的是图形客户端,但图形客户端不能解决所有的操作,所以,也少不了要需要使用命令行的时候. 但有些 Git 命令和参数确实又不好记,甚至有的命令每次要用的时候需 ...
- The Python Tutorial 和 documentation和安装库lib步骤
链接: The Python Tutorial : https://docs.python.org/3.6/tutorial/index.html Documentation: https://doc ...