POJ 1027 The Same Game(模拟)
题意 : 一个10×15的格子,有三种颜色的球,颜色相同且在同一片内的球叫做cluster(具体解释就是,两个球颜色相同且一个球可以通过上下左右到达另一个球,则这两个球属于同一个cluster,同时cluster含有至少两个球),每次选择cluster中包含同色球最多的进行消除,每次消除完之后,上边的要往下移填满空的地方,一列上的球移动之前与之后相对位置不变,如果有空列,右边的列往左移动,每一列相对位置不变 。
思路 : 模拟。。。。。。不停的递归。。。。。
- ////POJ 1027
- #include <iostream>
- #include <string>
- #include <cstdio>
- #include <cstring>
- using namespace std;
- int tmp,ans,tot,sum,k,xx,yy;
- //tmp:cluster中同色球的个数,ans:每次要消除的球的个数,tot:当前图中剩的总的有颜色的球,sum,分值,k:步数,xx,yy指的是要消除的cluster是从该点开始的
- bool v[][];
- string a[];
- char ch;
- int dx[] = {,,,-};
- int dy[] = {,,-,};
- void remov(int x,int y)//递归消除掉同色的
- {
- char c = a[x][y];
- a[x][y] = '';
- for (int i = ; i < ; i++)
- {
- int xx = x + dx[i];
- int yy = y + dy[i];
- if (xx >= && yy >= && xx < && yy < && a[xx][yy] == c)
- remov(xx,yy);
- }
- }
- void cluster(int x,int y)
- {
- tmp++;
- v[x][y] = ;
- for (int k = ; k < ; k++)
- {
- int xx = x + dx[k];
- int yy = y + dy[k];
- if (xx >= && yy >= && xx < && yy < && !v[xx][yy] && a[xx][yy]==a[x][y])
- cluster(xx,yy);
- }
- }
- int Find()
- {
- int maxx = ;
- memset(v,,sizeof(v));
- for (int j = ; j < ; j++)
- for (int i = ; i < ; i++)
- if (!v[i][j] && a[i][j]!='')
- {
- tmp = ;
- cluster(i,j);
- if (tmp > maxx)
- {
- maxx = tmp;
- ch = a[xx = i][yy = j];
- }
- }
- return maxx;
- }
- void fresh()
- {
- for (int j = ; j < ; j++)
- {
- int cnt = ;
- for (int i = ; i < ; i++)
- if (a[i][j] == '') cnt++;
- for (int i = ; i < -cnt ; i++)
- while (a[i][j]=='')//因为是倒着输入的,所以换不是往上换
- {
- int c = i;
- while (c != )
- {
- swap(a[c][j],a[c+][j]);
- c++;
- }
- }
- }
- int vis1[],tmpx = ;
- memset(vis1,,sizeof(vis1));
- for (int j = ; j < ; j++)//找空列
- {
- int cnt = ;
- for (int i = ; i < ; i++)
- if (a[i][j] == '') cnt++;
- if (cnt == )
- {
- vis1[j] = ;
- tmpx++;
- }
- }
- for (int j = ; j < -tmpx ; j++)
- while (vis1[j] == )
- {
- int c = j;
- while (c != )
- {
- for (int i = ; i < ; i++)
- swap(a[i][c],a[i][c+]);
- swap(vis1[c],vis1[c+]);
- c++;
- }
- }
- }
- int main()
- {
- int T ,casee = ;
- scanf("%d",&T);
- while(T--)
- {
- for (int i=; i>=; i--)
- cin >> a[i];
- printf("Game %d:\n\n",casee ++);
- tot = ;
- k = ;
- sum = ;
- while ()
- {
- ans = Find();
- if (ans <= ) break;
- printf("Move %d at (%d,%d): removed %d balls of color %c, got %d points.\n",
- k++,xx+,yy+,ans,ch,(ans-)*(ans-));
- tot -= ans;
- sum += (ans-)*(ans-);
- remov(xx,yy);
- fresh();
- }
- if (tot == ) sum += ;
- printf("Final score: %d, with %d balls remaining.\n\n",sum,tot);
- }
- return ;
- }
POJ 1027 The Same Game(模拟)的更多相关文章
- POJ 1027:The Same Game 较(chao)为(ji)复(ma)杂(fan)的模拟
The Same Game Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 5168 Accepted: 1944 Des ...
- poj 1008:Maya Calendar(模拟题,玛雅日历转换)
Maya Calendar Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 64795 Accepted: 19978 D ...
- POJ 3414 Pots【bfs模拟倒水问题】
链接: http://poj.org/problem?id=3414 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=22009#probl ...
- poj 2632 Crashing Robots(模拟)
链接:poj 2632 题意:在n*m的房间有num个机器,它们的坐标和方向已知,现给定一些指令及机器k运行的次数, L代表机器方向向左旋转90°,R代表机器方向向右旋转90°,F表示前进,每次前进一 ...
- poj 1028 Web Navigation(模拟)
题目链接:http://poj.org/problem? id=1028 Description Standard web browsers contain features to move back ...
- POJ 3087 Shuffle'm Up (模拟+map)
题目链接:http://poj.org/problem?id=3087 题目大意:已知两堆牌s1和s2的初始状态, 其牌数均为c,按给定规则能将他们相互交叉组合成一堆牌s12,再将s12的最底下的c块 ...
- POJ 1068 Parencodings【水模拟--数括号】
链接: http://poj.org/problem?id=1068 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=27454#probl ...
- POJ 3672 Long Distance Racing (模拟)
题意:给定一串字符,u表示是上坡,d表示下坡,f表示平坦的,每个有不同的花费时间,问你从开始走,最远能走到. 析:直接模拟就好了,没什么可说的,就是记下时间时要记双倍的,因为要返回来的. 代码如下: ...
- poj 1696 Space Ant(模拟+叉积)
Space Ant Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 3840 Accepted: 2397 Descrip ...
随机推荐
- OpenGL完整实例
结合上一节的内容,分享完整代码. 先画一个cube,然后通过OnGestureListener去触发onFling使它旋转起来. OnGestureListener相关的方法我已经都加了注释,可以参考 ...
- Golang之AES/DES加密解密
AES/DES加密/解密涉及4个概念:1. Block, 也叫分组, 相应加密/解密的算法. 2. BlockMode, 模式, 相应加密/解密的处理.3. InitalVectory, 初始向量4. ...
- Python修饰器的函数式编程
Python的修饰器的英文名叫Decorator,当你看到这个英文名的时候,你可能会把其跟Design Pattern里的Decorator搞混了,其实这是完全不同的两个东西.虽然好像,他们要干的事都 ...
- 自定义Drawable
本文由 伯乐在线 - treesouth 翻译,toolate 校稿.未经许可,禁止转载! 英文出处:ryanharter.com.欢迎加入翻译小组. 我们看过一些博客文章,讲述了为什么要适时地使用自 ...
- ios多线程和进程的区别(转载)
很想写点关于多进程和多线程的东西,我确实很爱他们.但是每每想动手写点关于他们的东西,却总是求全心理作祟,始终动不了手. 今天终于下了决心,写点东西,以后可以再修修补补也无妨. 一.为何需要多进程(或者 ...
- [转]What’s Behind Ericsson’s OpenWebRTC Project?
[转]What’s Behind Ericsson’s OpenWebRTC Project? http://www.tuicool.com/articles/z6rAVrJ Ericsson’s O ...
- 微信支付.NET版开发总结(JS API),好多坑,适当精简。
前2天,做一个手机网页的微信支付的项目,费了好些周折,记录一下.接下来,按照开发步骤,细数一下,我遇到的那些坑. [坑1]官方邮件中下载的demo只有PHP版本,其他版本没有给链接.可能让人误以为只有 ...
- java数据结构和算法------合并排序
package iYou.neugle.sort; public class Merge_sort { public static void MergeSort(double[] array, i ...
- mozilla css developer center
https://developer.mozilla.org/en-US/docs/Web/CSS
- STL之map
参见http://www.cplusplus.com/reference/map/map/ template < class Key, ...