博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1753 枚举二进制+BFS
阅读量:7098 次
发布时间:2019-06-28

本文共 1274 字,大约阅读时间需要 4 分钟。

搜了一下枚举的题 网上说这题特别经典 这是参考别人的代码,做个模板,运用二进制来保存棋盘,但一旦棋盘规模增大这种算法还是不行,再研究一下DFS的算法。

#include 
#include
using namespace std; int step[65535]; //记录步骤 bool flag[65535]; //防止重复搜索 unsigned short qState[65535]; //搜索的状态,正好可以用一个16位的无符号短整形表示 int rear = 0; //队列尾指针 int top = 0; //队列头指针 ///初始化:读入棋盘初始状态并把它转化为整数存入队列头,黑的位为1白的为0 void Init() { unsigned short temp = 0; char c; for(int i=0; i < 4; i++) for(int j = 0; j < 4; j++) { cin>>c; if('b' == c) temp |= (1<<(i*4+j)); } qState[rear++] = temp; flag[temp] = true; } ///翻转一个棋子并按规则对齐周围棋子附加影响 unsigned short move(unsigned short state, int i) { unsigned short temp=0; temp |= (1<
= 0) //上 temp |= (1<<(i-4)); return (state ^ temp); } //广度优先搜索,从队列中循环取出状态,并把翻转16次(即所有情况),一旦发现满足要求的立即停止,否则加入队列 bool BFS() { while(rear > top) { unsigned short state = qState[top++]; //qState.pop(); for(int i=0; i < 16; i++) { unsigned short temp; temp = move(state,i); if(0 == state || 65535 == state) { cout<
>c; }

转载于:https://www.cnblogs.com/amourjun/archive/2013/03/14/5134221.html

你可能感兴趣的文章
1751: [Usaco2005 qua]Lake Counting
查看>>
【BZOJ】4753: [Jsoi2016]最佳团体 01分数规划+树上背包
查看>>
iOS 获取设备信息之UIDevice的使用,Swift 基于 API
查看>>
IntelliJ cannot log in to GitHub上传github报错解决
查看>>
MySQL强制性操作
查看>>
timestamp与timedelta,管理信息系统概念与基础
查看>>
重写对象ToString方法
查看>>
备忘: C++中的 vector 容器
查看>>
smt中查看图片与视频缩略图中,如何获得小视频的长度。
查看>>
图片(img标签)的onerror事件
查看>>
2013应届毕业生“百度”校招应聘总结
查看>>
CentOS系统启动流程
查看>>
myEclipse的Aptana studio插件安装时出现Error opening the editor.
查看>>
Mysql 知识(1)
查看>>
根据不同选择显示不同单价的逻辑
查看>>
“整个场面我Hold住!”软件测试计划
查看>>
利用SmtpClient发送邮件
查看>>
线性表练习题1
查看>>
C# 面试题大全
查看>>
「THUPC2018」赛艇 / Citing
查看>>