其实就是一道搜索模拟题。因为数据量小,用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的更多相关文章

  1. 【二分】Codeforces 706B Interesting drink

    题目链接: http://codeforces.com/problemset/problem/706/B 题目大意: n (1 ≤ n ≤ 100 000)个商店卖一个东西,每个商店的价格Ai,你有m ...

  2. 【原创】小白学jquery Mobile《构建跨平台APP:jQuery Mobile移动应用实战》连载五(给按钮加图标)

    在范例5-4所使用的导航栏中,已经为按钮加入了图标的样式,但是当时并没有介绍按钮的图标究竟是怎么一回事.下面截取范例5-4中导航栏部分的代码: <divdata-role="foote ...

  3. 【HDOJ】4729 An Easy Problem for Elfness

    其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...

  4. 【HDOJ】【3506】Monkey Party

    DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...

  5. 【HDOJ】【3516】Tree Construction

    DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...

  6. 【HDOJ】【3480】Division

    DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...

  7. 【HDOJ】【2829】Lawrence

    DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...

  8. 【HDOJ】【3415】Max Sum of Max-K-sub-sequence

    DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...

  9. 【HDOJ】【3530】Subsequence

    DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...

随机推荐

  1. Qt 学习之路:自定义事件

    尽管 Qt 已经提供了很多事件,但对于更加千变万化的需求来说,有限的事件都是不够的.例如,我要支持一种新的设备,这个设备提供一种崭新的交互方式,那么,这种事件如何处理呢?所以,允许创建自己的事件 类型 ...

  2. WCF - 序列化

    数据是信息的载体 在不同环境中有不同的类型 为保证处于不同平台的的应用能够正常的进行数据交互 必须采用一种双方都能理解的数据类型 XML无疑是最好的选择 但不是唯一的选择 例如JSON也是一种普遍认可 ...

  3. HTTPS是如何保证连接安全:每位Web开发者都应知道的

    “HTTPS协议的工作原理是什么?”这是我在数天前工作项目中需要解决的问题. 作为一名Web开发者,我当然知道 HTTPS 协议是保障用户敏感数据的好办法,但并不知道这种协议的内在工作机制. 它怎么保 ...

  4. svs 在创建的时候 上传文件夹 bin obj 这些不要提交

    svs  在创建的时候 上传文件夹 bin  obj  这些不要提交  右键-去除版本控制并增加到忽略列表

  5. asp.net下载文件的几种方法

    最近做东西遇到了下载相关的问题.在这里总结一下自己处理的方法. 1.以字节流的形式向页面输出数据以下载Excel为例子. string path=Server.MapPath("文件路径&q ...

  6. 使用CDN加载jQuery类库后备代码

    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js"></ ...

  7. List(列表)

    List(列表): List的特征是其元素以线性方式存储,集合中可以存放重复对象. List接口主要实现类包括: ArrayList() : 代表长度可以改变得数组.可以对元素进行随机的访问,向Arr ...

  8. jQuery AJAX实现调用页面后台方法

    1.新建demo.aspx页面.2.首先在该页面的后台文件demos.aspx.cs中添加引用. using System.Web.Services; 3.无参数的方法调用. 大家注意了,这个版本不能 ...

  9. 在模型中获取网络数据,刷新tableView

    model .h #import <Foundation/Foundation.h> #import "AFHTTPRequestOperationManager.h" ...

  10. Vijos1523 NOI2002 贪吃的九头龙 树形dp

    思路不算很难,但细节处理很麻烦 前面建图.多叉转二叉,以及确定dp处理序列的过程都是套路,dp的状态转移过程以注释的形式阐述 #include <cstdio> #include < ...