14颜色方块(1)
来源:互联网 发布:软件著作权 邮寄证书 编辑:程序博客网 时间:2024/05/16 01:04
智力游戏
位置可以任选,但是格子是不能旋转的。
代码:
#include<iostream>#include<iomanip>using namespace std;char list[12][4];bool notBeLine(int i, int j){return list[i][2] != list[j][0] || list[i][3] != list[j][1];}bool notBeRow(int i, int j){return list[i][1] != list[j][0] || list[i][3] != list[j][2];}bool same(int i, int j, int k, int l, int x){return i == x || j == x || k == x || l == x;}bool main2(int i, int j, int k, int l);bool main3(int i, int j, int k, int l, int ri, int rj, int rk, int rl);int main(){cout << "输入每个格子的4个点的颜色,用任何字符代表颜色都可以" << endl;for (int i = 0; i < 12; i++)for (int j = 0; j < 4; j++)cin >> list[i][j];for (int i = 0; i < 12; i++){for (int j = 0; j < 12; j++){if (i == j || (notBeLine(i, j)))continue;for (int k = 0; k < 12; k++){if (i == k || j == k || (notBeLine(j, k)))continue;for (int l = 0; l < 12; l++){if (i == l || j == l || k == l)continue;if (notBeLine(k, l))continue;if (main2(i, j, k, l))return 0;}}}}}bool main2(int i, int j, int k, int l){for (int ri = 0; ri < 12; ri++){if (notBeRow(i, ri) || same(i, j, k, l, ri))continue;for (int rj = 0; rj < 12; rj++){if (notBeRow(j, rj) || same(i, j, k, l, rj))continue;if (ri == rj || (notBeLine(ri, rj)))continue;for (int rk = 0; rk < 12; rk++){if (notBeRow(k, rk) || same(i, j, k, l, rk))continue;if (ri == rk || rj == rk || (notBeLine(rj, rk)))continue;for (int rl = 0; rl < 12; rl++){if (notBeRow(l, rl) || same(i, j, k, l, rl))continue;if (ri == rl || rj == rl || rk == rl || notBeLine(rk, rl))continue;if (main3(i, j, k, l, ri, rj, rk, rl))return true;}}}}return false;}bool main3(int i, int j, int k, int l, int ri, int rj, int rk, int rl){for (int j1 = 0; j1 < 12; j1++){if (same(i, j, k, l, j1) || same(ri, rj, rk, rl, j1) || notBeRow(j1, j))continue;for (int j2 = 0; j2 < 12; j2++){if (same(i, j, k, l, j2) || same(ri, rj, rk, rl, j2) || notBeRow(rj, j2))continue;for (int k1 = 0; k1 < 12; k1++){if (same(i, j, k, l, k1) || same(ri, rj, rk, rl, k1) || notBeRow(k1, k))continue;if (j1 == j2 || j2 == k1 || k1 == j1)continue;for (int k2 = 0; k2 < 12; k2++){if (same(i, j, k, l, k2) || same(ri, rj, rk, rl, k2) || notBeRow(rk, k2))continue;if (j1 == k2 || j2 == k2 || k1 == k2)continue;if (notBeLine(j1, k1) || notBeLine(j2, k2))continue;cout << " " << setw(4) << i + 1 << setw(4) << ri + 1 << endl;cout << setw(4) << j1 + 1 << setw(4) << j + 1 << setw(4) << rj + 1 << setw(4) << j2 + 1 << endl;cout << setw(4) << k1 + 1 << setw(4) << k + 1 << setw(4) << rk + 1 << setw(4) << k2 + 1 << endl;cout << " " << setw(4) << l + 1 << setw(4) << rl + 1 << endl << endl;cout << "这是其中一种解法,数字1的位置表示第一个输入的格子应该排的位置,以此类推";system("pause>nul");return true;}}}}return false;}
0 0
- 14颜色方块(1)
- 145颜色方块(11)
- 122颜色方块(9)132(10)
- ps打造不规则颜色方块
- 71颜色方块(5)84(6)97(7)108(8)
- 26颜色方块(2)41(3)56(4)
- JS实现方块颜色的渐变
- 状态机(剑圣砍方块)
- 方块颜色由深变浅、由浅变深循环
- 方块消除 (黑书)
- POJ 2506(放方块)
- 去方块滤波(转载)
- [POJ1390]Blocks(方块消除)
- 用JavaScript语言编写:点击对应颜色的小方块更换主题颜色
- homerHEVC代码阅读(35)——环路滤波(1)去方块滤波
- 类Minecraft方块游戏unity开发笔记1-地形(mesh合并)
- Usaco 1.2.2 方块变换(Transformations)
- Egret开发《消灭方块》后记(一)
- YYModel V1.0.4源码解析
- linux下profile和bashrc区别
- RHEL6.5 7.2更改为阿里云(aliyun)CentOS6 163 CentOS7的yum源
- Java非对称加密算法RSA
- json和jsonP的区别和联系以及ajax和jsonP的区别
- 14颜色方块(1)
- 欢迎使用CSDN-markdown编辑器
- 利用File类来实现对文件和文件夹数目的统计
- 文章标题
- OpenJudge noi 1159Maze(poj 2157)
- 最小生成树
- log4j详细配置
- 利用unity3d自带的CharacterController包制作第一人称控制模型的简单Demo
- 导论