[BZOJ 1033] [ZJOI2008] 杀蚂蚁antbuster 【模拟!】
题目链接: BZOJ - 1033
题目分析
模拟!纯粹按照题目描述模拟!
这是一道喜闻乐见的经典模拟题!
我一共写了2遍,Debug 历时2天的所有晚自习 ... 时间超过 8h ... 我真是太弱了啊 ...
最终对着数据和 std 终于找到错误了!
错误:好好读题!不要忽略题意中的细节!在函数中提前退出的时候想想会不会有什么事情还没有做。
Warning!Warning!Warning!
注意在给 sort 写 Cmp 的时候,一定一定一定要保证比较结果双向统一! 若 Cmp(a, b) == false , 那么 Cmp(b, a) 一定要为 true !!!
否则就会跪掉!一定要注意!Cmp里有一些特殊条件判断的时候一定要注意这一点!
代码
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm> using namespace std; typedef double DB; const int MaxN = 8 + 3, MaxA = 6 + 3, MaxB = 20 + 3, INF = 999999999;
const int Dx[5] = {0, 1, 0, -1}, Dy[5] = {1, 0, -1, 0}; int n, m, B_s, B_d, B_r, Time, Ant_Index, Target, Ant_s, Over_Time, Lev_Now;
int Msg[MaxN][MaxN], Tgt[MaxB]; DB Hp_Now; bool Map[MaxN][MaxN]; inline int gmin(int a, int b) {return a < b ? a : b;}
inline int gmax(int a, int b) {return a > b ? a : b;} struct Battery
{
int x, y;
} B[MaxB]; inline bool OKP(int x, int y) {
if (x < 0 || x > n) return false;
if (y < 0 || y > m) return false;
return (!Map[x][y]);
} struct Ant
{
int Hp, Hp_Ceiling, Lev, Age, x, y, Lx, Ly;
bool Alive, Cake; Ant() {
x = y = 0;
Lx = Ly = -1;
Age = 0;
Lev = Lev_Now;
Hp = Hp_Ceiling = (int)Hp_Now;
Alive = true; Cake = false;
} void Move() {
int MaxMsg = -1, nk = -1, xx, yy;
for (int i = 0; i < 4; ++i) {
xx = x + Dx[i]; yy = y + Dy[i];
if (!OKP(xx, yy) || (xx == Lx && yy == Ly)) continue;
if (Msg[xx][yy] > MaxMsg) {
MaxMsg = Msg[xx][yy];
nk = i;
}
}
if (MaxMsg == -1) {
Lx = x; Ly = y;
return;
}
if ((Age + 1) % 5 == 0) {
while (true) {
nk = ((nk - 1) + 4) % 4;
xx = x + Dx[nk]; yy = y + Dy[nk];
if (!OKP(xx, yy) || (xx == Lx && yy == Ly)) continue;
break;
}
}
Lx = x; Ly = y;
x += Dx[nk]; y += Dy[nk];
Map[Lx][Ly] = false;
Map[x][y] = true;
} void GetCake() {
Cake = true;
Hp = gmin(Hp_Ceiling, Hp + (Hp_Ceiling >> 1));
} void Print() {
printf("%d %d %d %d %d\n", Age, Lev, Hp, x, y);
}
} A[MaxA]; void Init() {
for (int i = 1; i <= 6; ++i) {
A[i].Alive = false;
A[i].Cake = false;
}
Hp_Now = 4.4; Lev_Now = 1;
Ant_Index = 0;
memset(Map, 0, sizeof(Map));
for (int i = 1; i <= B_s; ++i) Map[B[i].x][B[i].y] = true;
memset(Msg, 0, sizeof(Msg));
Ant_s = 0;
Target = -1;
Over_Time = -1;
} void New_Ant_Born() {
if (Map[0][0] || Ant_s == 6) return;
++Ant_Index;
if (Ant_Index == 7) {
Ant_Index = 1;
Hp_Now *= 1.1;
++Lev_Now;
}
A[++Ant_s] = Ant();
Map[0][0] = true;
} void Add_Message() {
for (int i = 1; i <= Ant_s; ++i) {
if (Target == i) Msg[A[i].x][A[i].y] += 5;
else Msg[A[i].x][A[i].y] += 2;
}
} void Ant_Move() {
for (int i = 1; i <= Ant_s; ++i) {
A[i].Move();
if (Target == -1 && A[i].x == n && A[i].y == m) {
Target = i;
A[i].GetCake();
}
}
} inline int Sqr(int x) {return x * x;}
inline int Abs(int x) {return x < 0 ? -x : x;} int SqrDis(int x, int y, int xx, int yy) {
return Sqr(x - xx) + Sqr(y - yy);
} int Nearest(int x, int y) {
int MinDis = INF, Dx, ret;
for (int i = 1; i <= Ant_s; ++i) {
Dx = SqrDis(A[i].x, A[i].y, x, y);
if (Dx < MinDis) {
ret = i;
MinDis = Dx;
}
}
return ret;
} bool Intersect(int x, int y, int xa, int ya, int xb, int yb) {
if (x < gmin(xa, xb) || x > gmax(xa, xb) || y < gmin(ya, yb) || y > gmax(ya, yb)) return false;
int S2;
S2 = Abs(xa * yb + y * xb + x * ya - y * xa - x * yb - xb * ya);
S2 = Sqr(S2);
return (S2 * 4 <= SqrDis(xa, ya, xb, yb));
} void Battery_Attack() {
if (Target == -1)
for (int i = 1; i <= B_s; ++i) Tgt[i] = Nearest(B[i].x, B[i].y);
else
for (int i = 1; i <= B_s; ++i)
if (SqrDis(B[i].x, B[i].y, A[Target].x, A[Target].y) <= Sqr(B_r)) Tgt[i] = Target;
else Tgt[i] = Nearest(B[i].x, B[i].y);
for (int i = 1; i <= B_s; ++i) {
if (SqrDis(B[i].x, B[i].y, A[Tgt[i]].x, A[Tgt[i]].y) > Sqr(B_r)) continue;
for (int j = 1; j <= Ant_s; ++j)
if (Intersect(A[j].x, A[j].y, B[i].x, B[i].y, A[Tgt[i]].x, A[Tgt[i]].y))
A[j].Hp -= B_d;
}
int Temp = 0;
for (int i = 1; i <= Ant_s; ++i) {
if (A[i].Hp >= 0) continue;
A[i].Alive = false;
Map[A[i].x][A[i].y] = false;
if (A[i].Cake) {
Target = -1;
A[i].Cake = false;
}
++Temp;
}
Ant_s -= Temp;
} bool Check_Over() {
if (Target == -1) return false;
return (A[Target].x == 0 && A[Target].y == 0);
} void Decrease_Message() {
for (int i = 0; i <= n; ++i)
for (int j = 0; j <= m; ++j)
if (Msg[i][j] > 0) --Msg[i][j];
} bool Cmp(Ant a1, Ant a2) {
if (a1.Alive == false && a2.Alive) return false;
if (a1.Alive && a2.Alive == false) return true;
return a1.Age > a2.Age;
} void Update_Ant() {
sort(A + 1, A + 6 + 1, Cmp);
for (int i = 1; i <= Ant_s; ++i) {
++A[i].Age;
if (A[i].Cake) Target = i;
}
} void Print_Situation() {
printf("%d\n", Ant_s);
for (int i = 1; i <= Ant_s; ++i) A[i].Print();
} int main()
{
scanf("%d%d", &n, &m);
scanf("%d%d%d", &B_s, &B_d, &B_r);
for (int i = 1; i <= B_s; ++i)
scanf("%d%d", &B[i].x, &B[i].y);
scanf("%d", &Time); Init();
for (int i = 1; i <= Time; ++i) {
New_Ant_Born();
Add_Message();
Ant_Move();
Battery_Attack();
if (Check_Over()) {
sort(A + 1, A + 6 + 1, Cmp);
Over_Time = i;
break;
}
Decrease_Message();
Update_Ant();
}
if (Over_Time != -1) printf("Game over after %d seconds\n", Over_Time);
else printf("The game is going on\n");
Print_Situation();
return 0;
}
[BZOJ 1033] [ZJOI2008] 杀蚂蚁antbuster 【模拟!】的更多相关文章
- BZOJ 1033: [ZJOI2008]杀蚂蚁antbuster(模拟)
坑爹的模拟题QAQ DEBUG多了1kb QAQ 按题意做就行了 注意理解题意啊啊啊啊 尼玛输出忘换行wa了3次QAQ CODE: #include<cstdio>#include< ...
- [BZOJ 1033][ZJOI2008]杀蚂蚁antbuster
1033: [ZJOI2008]杀蚂蚁antbuster Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1200 Solved: 507[Submi ...
- BZOJ1033:[ZJOI2008]杀蚂蚁antbuster(模拟)
Description 最近,佳佳迷上了一款好玩的小游戏:antbuster.游戏规则非常简单:在一张地图上,左上角是蚂蚁窝,右 下角是蛋糕,蚂蚁会源源不断地从窝里爬出来,试图把蛋糕搬回蚂蚁窝.而你的 ...
- [ZJOI2008]杀蚂蚁antbuster
[ZJOI2008]杀蚂蚁antbuster 题目 最近,佳佳迷上了一款好玩的小游戏:antbuster.游戏规则非常简单:在一张地图上,左上角是蚂蚁窝,右下角是蛋糕,蚂蚁会源源不断地从窝里爬出来,试 ...
- P2586 [ZJOI2008]杀蚂蚁(模拟)
P2586 [ZJOI2008]杀蚂蚁 大模拟. 什么都不想补了. 看变量名感性理解吧 #include<iostream> #include<cstdio> #include ...
- 【BZOJ 1033】 [ZJOI2008]杀蚂蚁antbuster
Description 最近,佳佳迷上了一款好玩的小游戏:antbuster.游戏规则非常简单:在一张地图上,左上角是蚂蚁窝,右下角是蛋糕,蚂蚁会源源不断地从窝里爬出来,试图把蛋糕搬回蚂蚁窝.而你的任 ...
- bzoj千题计划121:bzoj1033: [ZJOI2008]杀蚂蚁antbuster
http://www.lydsy.com/JudgeOnline/problem.php?id=1033 经半个下午+一个晚上+半个晚上 的 昏天黑地调代码 最终成果: codevs.洛谷.tyvj上 ...
- [bzoj1033] [ZJOI2008]杀蚂蚁antbuster
Description 最近,佳佳迷上了一款好玩的小游戏:antbuster.游戏规则非常简单:在一张地图上,左上角是蚂蚁窝,右下角是蛋糕,蚂蚁会源源不断地从窝里爬出来,试图把蛋糕搬回蚂蚁窝.而你的任 ...
- [ZJOI2008]杀蚂蚁antbuster 题解
一个题目的可读版本:https://www.zybuluo.com/Jerusalem/note/221811 这两天做的又一道大模拟题,感觉这玩意有毒,会上瘾啊…… 比起猪国杀这道题真心不知道高到哪 ...
随机推荐
- 使用JUnit测试java代码
Junit 单元测试实验报告 一.实验环境 MyEclipse2014.Junit4.10 二.实验目的 学会单元测试,在MyEclipse中进行Junit测试 三.实验步骤 1.写出要测试的类 代 ...
- HDU3336-Count the string(KMP)
Count the string Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- C. Tourist Problem
http://codeforces.com/problemset/problem/340/C 赛时没想出赛后却能较快想出深深的教育自己做题一定要静下心来,不要轻易放弃,认真思考,不要浮躁着急,不要太容 ...
- 如何使用node中的buffer
介绍:Buffer类是一个全局类,是一个比较罕见不需要require( ‘buffer’ )就可以使用的类,Buffer类似与数组也有length, 它里面的元素为16进制的两位数,即 0-255的数 ...
- webUploader上传组件 实际运用小结
WebUploader组件实际介绍: 官网:http://fex.baidu.com/webuploader/doc/index.html 组件优势及优化总结:http://itindex.net/d ...
- winform(C#)拖拽实现获得文件路径
设置Form的AllowDrop为true private void Form1_DragDrop(object sender, DragEventArgs e) { ...
- java 从jar包中读取资源文件
在代码中读取一些资源文件(比如图片,音乐,文本等等),在集成环境(Eclipse)中运行的时候没有问题.但当打包成一个可执行的jar包(将资源文件一并打包)以后,这些资源文件找不到,如下代码: Jav ...
- SpringMVC4+thymeleaf3的一个简单实例(篇四:form表单数据验证)
关于表单数据验证有很多中方法,这里我仅介绍JSR303注解验证.JSR303仅仅是一个规范,这里我们要用到它的一个实现:hibernate-validator. 注意在spring的配置文件sprin ...
- SpringMVC4+thymeleaf3的一个简单实例(篇一:基本环境)
首语:用SpringMVC和thymeleaf实现一个简单的应用,包括基本环境搭建,SpringMVC4和thymeleaf3的整合,页面参数的获取,页面参数验证,以及用MySQL保存数据.我会把步骤 ...
- linux 部分命令简单使用介绍-ssh、scp、less、tail、find、grep(持续添加)
ssh 加密的网络协议,提供客户-服务模式. 登录 ssh username@ip ssh ip #不提供用 ...