POJ2222+暴力搜索
一共2^15个状态
比较简单
/*
2^15 states
*/
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#include<algorithm>
using namespace std; const int maxn = ;
const int inf = ;
const int dx[]={,,,-,,-,,-};
const int dy[]={,-,,,-,,,-};
char mat[ ][ ];
struct Node{
int x,y;
char ch;
bool flag;
}node[ ];
int vis[ ]; bool in( int x,int y,int n,int m ){
if( x>=&&x<n&&y>=&&y<m ) return true;
else return false;
} bool ok_k( int x,int y,int n,int m ){
for( int i=;i<;i++ ){
int tx = x+dx[i];
int ty = y+dy[i];
if( in(tx,ty,n,m)==true ) {
if( mat[tx][ty]!='E' )
return false;
}
}
return true;
}
bool ok_q( int x,int y,int n,int m ){
for( int i=;i<=;i++ ){
for( int k=;k<;k++ ){
int tx = x+i*dx[k];
int ty = y+i*dy[k];
if( in(tx,ty,n,m)==true ){
if( mat[tx][ty]!='E' )
return false;
}
}
}
return true;
}
bool ok_b( int x,int y,int n,int m ){
for( int i=;i<=;i++ ){
for( int k=;k<;k++ ){
int tx = x+i*dx[k];
int ty = y+i*dy[k];
if( in(tx,ty,n,m)==true ){
if( mat[tx][ty]!='E' )
return false;
}
}
}
return true;
}
bool ok_r( int x,int y,int n,int m ){
for( int i=;i<=;i++ ){
for( int k=;k<;k++ ){
int tx = x+i*dx[k];
int ty = y+i*dy[k];
if( in(tx,ty,n,m)==true ){
if( mat[tx][ty]!='E' )
return false;
}
}
}
return true;
}
bool ok_n( int x,int y,int cnt_node ){
for( int i=;i<cnt_node;i++ ){
if( node[i].x==x&&node[i].y==y ) continue;
if( node[i].flag==false ) continue;
int ddx = abs( x-node[i].x );
int ddy = abs( y-node[i].y );
if( (ddx==&&ddy==)||(ddx==&&ddy==) )
return false;
}
return true;
} void re( int cnt_node ){
for( int i=;i<cnt_node;i++ ){
if( vis[ i ]== ){
mat[ node[i].x ][ node[i].y ] = node[i].ch;
node[ i ].flag = true;
}
}
} bool judge( int cnt_node,int n,int m ){
for( int i=;i<cnt_node;i++ ){
if( vis[ i ]== ){
mat[ node[i].x ][ node[i].y ] = 'E';
node[ i ].flag = false;
}
}
bool flag = true;
for( int i=;i<n;i++ ){
for( int j=;j<m;j++ ){
if( mat[i][j]=='E' )
continue;
if( mat[i][j]=='N'&&ok_n( i,j,cnt_node )==false ){
flag = false;
break;
}
else if( mat[i][j]=='R'&&ok_r( i,j,n,m )==false ){
flag = false;
break;
}
else if( mat[i][j]=='B'&&ok_b( i,j,n,m )==false ){
flag = false;
break;
}
else if( mat[i][j]=='Q'&&ok_q( i,j,n,m )==false ){
flag = false;
break;
}
else if( mat[i][j]=='K'&&ok_k( i,j,n,m )==false ){
flag = false;
break;
}
}
if( flag==false ) break;
}
re( cnt_node );
return flag;
} int main(){
char s[ ];
while( scanf("%s",&s)!=EOF ){
int n,m;
int cnt_node = ;
scanf("%d%d",&m,&n);
for( int i=;i<n;i++ ){
for( int j=;j<m;j++ ){
scanf("%s",s);
mat[i][j] = s[];
if( s[]!='E' ){
node[ cnt_node ].x = i;
node[ cnt_node ].y = j;
node[ cnt_node ].flag = true;
node[ cnt_node++ ].ch = s[];
}
}
}
scanf("%s",s);
int N = (<<cnt_node);
//printf("cnt_node=%d\n",cnt_node);
int ans = inf;
for( int i=;i<N;i++ ){
int temp_ans = ;
for( int j=;j<cnt_node;j++ ){
if( i&(<<j) ) {vis[ j ] = ,temp_ans++;}
else vis[ j ] = ;
}
if( judge( cnt_node,n,m )==true ){
ans = min( ans,temp_ans );
}
}
printf("Minimum Number of Pieces to be removed: %d\n",ans);
}
return ;
}
POJ2222+暴力搜索的更多相关文章
- ACM 暴力搜索题 题目整理
UVa 129 Krypton Factor 注意输出格式,比较坑爹. 每次要进行处理去掉容易的串,统计困难串的个数. #include<iostream> #include<vec ...
- hdu 4740 The Donkey of Gui Zhou(暴力搜索)
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=4740 [题意]: 森林里有一只驴和一只老虎,驴和老虎互相从来都没有见过,各自自己走过的地方不能走第二次 ...
- hdu 1427 速算24点 dfs暴力搜索
速算24点 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Problem De ...
- 随手练——洛谷-P1151(枚举与暴力搜索)
枚举 #include <iostream> using namespace std; int main() { ; cin >> k; ; i < ; i++) { ) ...
- 枚举进程——暴力搜索内存(Ring0)
上面说过了隐藏进程,这篇博客我们就简单描述一下暴力搜索进程. 一个进程要运行,必然会加载到内存中,断链隐藏进程只是把EPROCESS从链表上摘除了,但它还是驻留在内存中的.这样我们就有了找到它的方法. ...
- [luogu 1092] 虫食算 (暴力搜索剪枝)
传送门 Description Input 包含四行. 第一行有一个正整数 (N≤26). 后面的三行,每行有一个由大写字母组成的字符串,分别代表两个加数以及和.这3个字符串左右两端都没有空格,从高位 ...
- HDU 3131 One…Two…Five! (暴力搜索)
题目链接:pid=3131">HDU 3131 One-Two-Five! (暴力搜索) 题意:给出一串数字,要求用加,减,乘,除(5/2=2)连接(计算无优先级:5+3*6=8*6= ...
- 吴裕雄 python 机器学习——模型选择参数优化暴力搜索寻优GridSearchCV模型
import scipy from sklearn.datasets import load_digits from sklearn.metrics import classification_rep ...
- POJ 1129:Channel Allocation 四色定理+暴力搜索
Channel Allocation Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 13357 Accepted: 68 ...
随机推荐
- 搭建scala开发环境
下载scala 2.11.5 安装eclipse LUNA版本 安装scala IDE插件:http://download.scala-ide.org/sdk/lithium/e44/scala211 ...
- poj2337 欧拉路径
poj2337 这道题昨天晚上开始做,今天才A.但是问题想透了, 发现其实没那么难 题目大意: 给你一些单词,如果一个单词的末尾字符与另一个单词首字符相同,则两个的单词可以连接.问是否可以把所有单词连 ...
- 修改placeholder颜色
#contact_info为textarea的ID #contact_info::-webkit-input-placeholder{ color:#999;}#contact_info:-moz-p ...
- 方法 :PHP开发环境搭建(phpstorm + xampp+mongodb)
phpstorm 安装下载 百度网盘资源 phpstorm 9.0.1(有序列号) http://pan.baidu.com/s/1kTvX0jl xampp 安装下载 ...
- Python快速入门学习笔记(二)
注:本学习笔记参考了廖雪峰老师的Python学习教程,教程地址为:http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb49318210 ...
- 学习C++ Primer 的个人理解(十)
标准库没有给每个容器都定义成员函数来实现 查找,替换等操作.而是定义了一组泛型算法,他们可以用于不同类型的元素或多种容器类型. 迭代器令算法不依赖与容器 算法永远不会执行容器的操作 算法本身不会执行容 ...
- Cabarc Overview (Microsoft TechNet)
Original Link: Cabarc Overview Applies To: Windows Server 2003, Windows Server 2003 R2, Windows Ser ...
- vim 的 tags 模块 与 ctags
1. 概述 一般来说,在代码中跳转,离不开 ctags. 实际上,vim 中代码跳转是由 vim tags 模块完成的,tags 模块依赖于 tags 文件. ctags(Generate tag f ...
- Poj 2159 / OpenJudge 2159 Ancient Cipher
1.链接地址: http://poj.org/problem?id=2159 http://bailian.openjudge.cn/practice/2159 2.题目: Ancient Ciphe ...
- OpenJudge 2811 熄灯问题 / Poj 1222 EXTENDED LIGHTS OUT
1.链接地址: http://bailian.openjudge.cn/practice/2811 http://poj.org/problem?id=1222 2.题目: 总时间限制: 1000ms ...