【HDOJ】3295 An interesting mobile game
其实就是一道搜索模拟题。因为数据量小,用char就够了。
/* 3295 */
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <queue>
using namespace std; typedef struct {
char m[][];
char x, y;
char s, c;
} node_t; typedef struct subNode_t {
char x, y;
subNode_t() {}
subNode_t(char xx, char yy) {
x = xx; y = yy;
}
} subNode_t; bool visit[][];
node_t beg, cur;
int n, m, cnt;
char dir[][] = {
-,,,-,,,,
};
queue<node_t> Q;
queue<subNode_t> q; inline bool check(char x, char y) {
return x< || x>=n || y< || y>=m;
} void remove(char x, char y, char cl) {
char i, j, k;
subNode_t nd; ++cur.s;
cur.m[x][y] = ;
visit[x][y] = true;
--cur.c;
q.push(subNode_t(x, y)); while (!q.empty()) {
nd = q.front();
q.pop();
for (i=; i<; ++i) {
x = nd.x + dir[i][];
y = nd.y + dir[i][];
if (check(x, y) || visit[x][y])
continue;
if (cur.m[x][y] == cl) {
cur.m[x][y] = ;
visit[x][y] = true;
--cur.c;
q.push(subNode_t(x, y));
}
}
}
} node_t shift() {
char i, j, k, r;
bool flag;
node_t nd; // copy from cur
nd.s = cur.s;
nd.c = cur.c;
nd.x = cur.x;
nd.y = cur.y;
memset(nd.m, , sizeof(nd.m)); // fall down
r = ;
for (j=; j<m; ++j) {
k = n-;
for (i=n-; i>=; --i)
if (cur.m[i][j])
nd.m[k--][r] = cur.m[i][j];
if (k < n-)
++r;
} return nd;
} char bfs() {
char i, j, k;
node_t nd; while (!Q.empty())
Q.pop(); memset(visit, false, sizeof(visit));
for (i=; i<n; ++i) {
for (j=; j<n; ++j) {
if (beg.m[i][j] && !visit[i][j]) {
cur = beg;
remove(i, j, beg.m[i][j]);
nd = shift();
Q.push(nd);
}
}
} while (!Q.empty()) {
beg = Q.front();
Q.pop();
if (beg.c == )
return beg.s;
memset(visit, false, sizeof(visit));
for (i=; i<n; ++i) {
for (j=; j<m; ++j) {
if (beg.m[i][j] && !visit[i][j]) {
cur = beg;
remove(i, j, beg.m[i][j]);
nd = shift();
Q.push(nd);
}
}
}
} return ;
} int main() {
int i, j, k; #ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
#endif while (scanf("%d%d",&n,&m) != EOF) {
cnt = ;
beg.s = ;
for (i=; i<n; ++i) {
for (j=; j<m; ++j) {
scanf("%d", &k);
beg.m[i][j] = k;
if (k)
++cnt;
}
}
beg.c = cnt;
k = bfs();
printf("%d\n", k);
} return ;
}
【HDOJ】3295 An interesting mobile game的更多相关文章
- 【二分】Codeforces 706B Interesting drink
题目链接: http://codeforces.com/problemset/problem/706/B 题目大意: n (1 ≤ n ≤ 100 000)个商店卖一个东西,每个商店的价格Ai,你有m ...
- 【原创】小白学jquery Mobile《构建跨平台APP:jQuery Mobile移动应用实战》连载五(给按钮加图标)
在范例5-4所使用的导航栏中,已经为按钮加入了图标的样式,但是当时并没有介绍按钮的图标究竟是怎么一回事.下面截取范例5-4中导航栏部分的代码: <divdata-role="foote ...
- 【HDOJ】4729 An Easy Problem for Elfness
其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...
- 【HDOJ】【3506】Monkey Party
DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...
- 【HDOJ】【3516】Tree Construction
DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...
- 【HDOJ】【3480】Division
DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...
- 【HDOJ】【2829】Lawrence
DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...
- 【HDOJ】【3415】Max Sum of Max-K-sub-sequence
DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...
- 【HDOJ】【3530】Subsequence
DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...
随机推荐
- VMware安装CentOS后网络设置
在使用CentOS虚拟机后,出现了无法上网的情况,使用主机ping虚机地址可以ping通,而虚机ping不通主机,同时虚机也无法ping通其他的网址或ip,显示内容为Network is unreac ...
- Android&Java的学习新的等
学习资料 很久没写博客了.适逢这次Srtp项目学弟学妹们要学习Java与Android,我就总结一些学习的教材.方法,分享写材料与心得.纯个人观点,如有不周之处欢迎指出,大家共同探讨提高. *** 教 ...
- PHP利用超级全局变量$_GET来接收表单数据。
我们在linux上用 touch php_get.html php_get.php创建两个文件. php_get.html文件的代码如下: <!doctype html> <html ...
- JS实现一键复制功能
var copyClick = function (d) { var Url2 = $(d).parent().parent().find("#copy_value"); Url2 ...
- Oracle --1536错误解决(超出表空间)
--导入数据库时提示 超出表空间限额,1536错误,解决方法:去除限额. 执行:--alter user username quota unlimited on users; 例: alter use ...
- 关于pv的那些事!!
遗留问题:whid=1969的日志记录是什么意思? 网站站点信息未分配的时候,会用1969去代替站点信息. PV:页面浏览量(page view),用户每次打开或刷新一次网页即被计算一次. 关于pv的 ...
- KineticJS教程(1-2)
1.基本结构 KineticJS首先是要绑定到HTML页面上的一个DOM容器元素上,比如最常用的<div>标签.KineticJS在此容器中创建一个称之为舞台(stage)的结构,这个舞台 ...
- ViewPager和SwipeRefreshLayout之间嵌套使用时发生"事件"冲突
有时候我们会有一种需求,一个ViewPager有n个页面,每个页面是一个Fragment,在Fragment中使用了具有垂直滑动属性的控件,比如SwipeRefreshLayout!!! 这时二者之间 ...
- php文件粘贴上传
<?php header("Access-Control-Allow-Origin:*"); $url = 'http://'.$_SERVER['HTTP_HOST']; ...
- 【POJ3580】【块状链表】SuperMemo
Description Your friend, Jackson is invited to a TV show called SuperMemo in which the participant i ...