坑爹的模拟题QAQ DEBUG多了1kb QAQ

按题意做就行了

注意理解题意啊啊啊啊

尼玛输出忘换行wa了3次QAQ

CODE:

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
struct node{
 int x,y,lx,ly;
 bool flag,alive;
 int age;
 int hp;
 double mx;
 int level;
}ant[8];
#define maxn 200100
double hp[maxn+10];
int map[20][20];//信息素
bool bo[20][20];
int p[30][2];
int w[4][2]={{0,1},{1,0},{0,-1},{-1,0}};
int dist(int x1,int y1,int x2,int y2){
 return (x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
}
double xa(int x1,int y1,int x2,int y2){
 return x1*y2-x2*y1;
}
bool cross(int x1,int y1,int x2,int y2,int x3,int y3){
 double d=sqrt(dist(x1,y1,x2,y2));
 if (x1==x3&&y1==y3) return 1;
 if (x2==x3&&y2==y3) return 1;
 int mxx=max(x1,x2),mxy=max(y1,y2),mnx=min(x1,x2),mny=min(y1,y2);
 if (mxx<x3||mxy<y3||mnx>x3||mny>y3) return 0;
 if (fabs(xa(x1-x3,y1-y3,x2-x3,y2-y3))/d<=0.5) return 1;
 return 0;
}
int init(){
 hp[0]=4;
 for (int i=1;i<=maxn;i++)
  if (i%6==1) hp[i]=1.1*hp[i-1];
  else hp[i]=hp[i-1];
}
int sum=0;
int born(int x){
 if (bo[0][0]) return 0;
 sum++;
 ant[x]=(node){0,0,0,0,0,1,0,hp[sum],hp[sum],(sum-1)/6+1};
 bo[0][0]=1;
 return 0;
}
bool cmp(node x,node y){
 if (x.alive&&y.alive) return x.age>y.age;
 return x.alive>y.alive;
}
int n,m;
bool iscake=1;
int move(int x){
 for (int t=1;t<=6&&ant[t].alive;t++) map[ant[t].x][ant[t].y]+=ant[t].flag?5:2;
 for (int t=1;t<=6&&ant[t].alive;t++){
  bool b=0;
  for (int i=0;i<4;i++){
   int nowx=ant[t].x+w[i][0],nowy=ant[t].y+w[i][1];
   if (nowx>=0&&nowx<=n&&nowy>=0&&nowy<=m&&!bo[nowx][nowy]&&(nowx!=ant[t].lx||nowy!=ant[t].ly)) b=1;
  }
  if (!b) {
    ant[t].lx=ant[t].x;ant[t].ly=ant[t].y;continue;
  }
  bo[ant[t].x][ant[t].y]=0;
  int mx=-0x7fffffff;
  for (int i=0;i<4;i++){
   int nowx=ant[t].x+w[i][0],nowy=ant[t].y+w[i][1];
   if (nowx>=0&&nowx<=n&&nowy>=0&&nowy<=m&&!bo[nowx][nowy]&&(nowx!=ant[t].lx||nowy!=ant[t].ly))
    mx=max(mx,map[nowx][nowy]);
  }
  for (int i=0;i<4;i++){
   int nowx=ant[t].x+w[i][0],nowy=ant[t].y+w[i][1];
   if (nowx>=0&&nowx<=n&&nowy>=0&&nowy<=m&&!bo[nowx][nowy]&&map[nowx][nowy]==mx&&(nowy!=ant[t].ly||nowx!=ant[t].lx)) {
    if ((ant[t].age+1)%5!=0) {
     swap(ant[t].x,ant[t].lx);
     swap(ant[t].y,ant[t].ly);
     ant[t].x=nowx;
     ant[t].y=nowy;
    }else for (int j=(i-1+4)%4;;j=(j-1+4)%4){
     int nowx=ant[t].x+w[j][0],nowy=ant[t].y+w[j][1];
     if (nowx>=0&&nowx<=n&&nowy>=0&&nowy<=m&&!bo[nowx][nowy]&&(nowy!=ant[t].ly||nowx!=ant[t].lx)) {
      swap(ant[t].x,ant[t].lx);
      swap(ant[t].y,ant[t].ly);
      ant[t].x=nowx;
      ant[t].y=nowy;
      break;
     }
    }
    break;
   }
  }
  bo[ant[t].x][ant[t].y]=1;
 }
 for (int t=1;t<=6&&ant[t].alive;t++)
  if (ant[t].x==n&&ant[t].y==m&&iscake){
   iscake=0;ant[t].flag=1;ant[t].hp=min(ant[t].hp+(int) (ant[t].mx)/2, (int) ant[t].mx);
  }
 return 0;
}
int r,d;
int attack(int x){
 int target=0;
 for (int t=1;t<=6&&ant[t].alive;t++)
  if (ant[t].flag&&dist(p[x][0],p[x][1],ant[t].x,ant[t].y)<=r*r) target=t;
 if (!target)
  for (int t=1;t<=6&&ant[t].alive;t++)
   if ((!target&&dist(p[x][0],p[x][1],ant[t].x,ant[t].y)<=r*r)||
   (target&&dist(p[x][0],p[x][1],ant[t].x,ant[t].y)<dist(p[x][0],p[x][1],ant[target].x,ant[target].y))) target=t;
 if (!target) return 0;
 for (int t=1;t<=6&&ant[t].alive;t++)
 if (cross(p[x][0],p[x][1],ant[target].x,ant[target].y,ant[t].x,ant[t].y)) ant[t].hp-=d;
 return 0;
}
bool check(){
 for (int t=1;t<=6&&ant[t].alive;t++){
  if (ant[t].hp<0) {
   ant[t].alive=0;
   bo[ant[t].x][ant[t].y]=0;
   if (ant[t].flag) iscake=1;
  }
 }
 for (int t=1;t<=6;t++) {
  if (!ant[t].alive) continue;
  if (ant[t].flag&&ant[t].x==0&&ant[t].y==0) return 1;
 }
 return 0;
}
int ending(){
 for(int i=0;i<=n;i++)
  for (int j=0;j<=m;j++)
   map[i][j]=max(0,map[i][j]-1);
 for (int i=1;i<=6;i++) ant[i].age++;
 return 0;
}
int s;
int solve(int x){
 for (int i=1;i<=6;i++)
  if (!ant[i].alive) {born(i);break;}
 sort(ant+1,ant+7,cmp);
 move(x);
 for (int i=1;i<=s;i++) attack(i); 
 if (check())return 1;
 ending();
 return 0;
}
int endprint(){
 sort(ant+1,ant+7,cmp);
 int sum;
 for (sum=1;sum<=6&&ant[sum].alive;sum++);
 printf("%d\n",sum-1);
 for (int i=1;i<=6&&ant[i].alive;i++) printf("%d %d %d %d %d\n",ant[i].age,ant[i].level,ant[i].hp,ant[i].x,ant[i].y);
 return 0;
}
int main(){
 init();
 scanf("%d%d",&n,&m);
 scanf("%d%d%d",&s,&d,&r);
 for (int i=1;i<=s;i++) {
  scanf("%d%d",&p[i][0],&p[i][1]);
  bo[p[i][0]][p[i][1]]=1;
 }
 int T;bool b=1;
 scanf("%d",&T);
 for (int i=1;i<=T;i++){
  if (solve(i)) {
   printf("Game over after %d seconds\n",i);
   b=0;
   break;
  }
 }
 if (b) printf("The game is going on\n");
 endprint();
 return 0;
}

BZOJ 1033: [ZJOI2008]杀蚂蚁antbuster(模拟)的更多相关文章

  1. [BZOJ 1033][ZJOI2008]杀蚂蚁antbuster

    1033: [ZJOI2008]杀蚂蚁antbuster Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1200  Solved: 507[Submi ...

  2. [BZOJ 1033] [ZJOI2008] 杀蚂蚁antbuster 【模拟!】

    题目链接: BZOJ - 1033 题目分析 模拟!纯粹按照题目描述模拟! 这是一道喜闻乐见的经典模拟题! 我一共写了2遍,Debug 历时2天的所有晚自习 ... 时间超过 8h ... 我真是太弱 ...

  3. BZOJ1033:[ZJOI2008]杀蚂蚁antbuster(模拟)

    Description 最近,佳佳迷上了一款好玩的小游戏:antbuster.游戏规则非常简单:在一张地图上,左上角是蚂蚁窝,右 下角是蛋糕,蚂蚁会源源不断地从窝里爬出来,试图把蛋糕搬回蚂蚁窝.而你的 ...

  4. [ZJOI2008]杀蚂蚁antbuster

    [ZJOI2008]杀蚂蚁antbuster 题目 最近,佳佳迷上了一款好玩的小游戏:antbuster.游戏规则非常简单:在一张地图上,左上角是蚂蚁窝,右下角是蛋糕,蚂蚁会源源不断地从窝里爬出来,试 ...

  5. P2586 [ZJOI2008]杀蚂蚁(模拟)

    P2586 [ZJOI2008]杀蚂蚁 大模拟. 什么都不想补了. 看变量名感性理解吧 #include<iostream> #include<cstdio> #include ...

  6. 【BZOJ 1033】 [ZJOI2008]杀蚂蚁antbuster

    Description 最近,佳佳迷上了一款好玩的小游戏:antbuster.游戏规则非常简单:在一张地图上,左上角是蚂蚁窝,右下角是蛋糕,蚂蚁会源源不断地从窝里爬出来,试图把蛋糕搬回蚂蚁窝.而你的任 ...

  7. bzoj千题计划121:bzoj1033: [ZJOI2008]杀蚂蚁antbuster

    http://www.lydsy.com/JudgeOnline/problem.php?id=1033 经半个下午+一个晚上+半个晚上 的 昏天黑地调代码 最终成果: codevs.洛谷.tyvj上 ...

  8. [bzoj1033] [ZJOI2008]杀蚂蚁antbuster

    Description 最近,佳佳迷上了一款好玩的小游戏:antbuster.游戏规则非常简单:在一张地图上,左上角是蚂蚁窝,右下角是蛋糕,蚂蚁会源源不断地从窝里爬出来,试图把蛋糕搬回蚂蚁窝.而你的任 ...

  9. [ZJOI2008]杀蚂蚁antbuster 题解

    一个题目的可读版本:https://www.zybuluo.com/Jerusalem/note/221811 这两天做的又一道大模拟题,感觉这玩意有毒,会上瘾啊…… 比起猪国杀这道题真心不知道高到哪 ...

随机推荐

  1. 【bug】java.lang.NoSuchMethodError: android.widget.TextView.setBackground

    安卓的背景色设置需要根据SDK的版本来分情况考虑: if (Build.VERSION.SDK_INT >= 16) { textView.setBackground(null); } else ...

  2. css清除浮动大全,共8种方法

    我看的网页的网址:http://hi.baidu.com/kongcheng2012/item/2b1250d4452e802538f6f705 为什么浮动这么难? 因为浮动会使当前标签产生向上浮的效 ...

  3. HNU 13081 Even Up Solitaire解题报告

    题目大意:给定一个数组,若相邻的两个数之和为偶数,则将此两个数移除,通过这种方法将满足条件得数移除后数组还剩多少个数. 此题太水,不做解释.直接代码之: #include <stdio.h> ...

  4. Angular - - 脏值检查及其相关

    今天突然就想写写$digest和$apply,这些都是脏值检查的主体内容. 先以普通js来做一个简单的监控例子吧: var div = ducoment.getElementById("my ...

  5. jquery换肤

    <script src="script/jquery-2.1.0.js"></script>      <link href="style/ ...

  6. HDU-1166-敌兵布阵(线段树)

    前言: 线段树是一种二叉搜索树,与区间树相似,它将一个区间划分成一些单元区间,每个单元区间对应线段树中的一个叶结点.       对于线段树中的每一个非叶子节点[a,b],它的左儿子表示的区间为[a, ...

  7. TTP 错误 404.3 - Not Found 由于扩展配置问题而无法提供您请求的页面。如果该页面是脚本,请添加处理程序。如果应下载文件,请添加 MIME 映射。

    解决办法一: 控制面板->打开或关闭windows功能->Internet信息服务->万维网服务->应用程序开发功能. 勾选上“.net扩展性”和“ASP.NET”,保存后,重 ...

  8. Canvas 图片灰度

    我们可以通过下面几种方法,将其转换为灰度: 1.浮点算法:Gray=R*0.3+G*0.59+B*0.11 2.整数方法:Gray=(R*30+G*59+B*11)/100 3.移位方法:Gray = ...

  9. Word常用实用知识1

    Word常用实用知识1 纯手打,可能有错别字,使用的版本是office Word 2013 转载请注明出处,谢谢. 快速输入日期(含格式) [插入]--[日期]   快速输入日期和时间(快捷键) 快速 ...

  10. 为什么我最终替换掉了NATS

    之前公司没有使用msmq/rebbitmq等消息队列,一方面是觉得太重,想避免在引入中间件.另外的原因是公司的业务并不需要消息持久化和确保可送达(at-least-once VS at-more-on ...