UESTC_秋实大哥与战争 2015 UESTC Training for Data Structures<Problem D>

D - 秋实大哥与战争

Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others)

Submit Status

男儿何不带吴钩,收取关山五十州。

征战天下是秋实大哥一生的梦想,所以今天他又在练习一个对战游戏。

秋实大哥命令所有士兵从左到右排成了一行来抵挡敌人的攻击。

敌方每一次会攻击一个士兵,这个士兵就会阵亡,整个阵列就会从这个位置断开;同时有的时候已阵亡的士兵会受人赢气息感染而复活。

秋实大哥想知道某一时刻某一个士兵所在的阵列的长度是多少。

Input

第一行包含两个整数n,m,表示秋实大哥的士兵数目和接下来发生的事件数目。

接下来m行,每一行是以下三种事件之一:

0 x : 表示x位置的士兵受到攻击阵亡
1 x : 表示x位置的士兵受人赢气息感染复活
2 x : 秋实大哥想知道第x个士兵所在阵列的长度

1≤n,m≤100000,1≤x≤n。

Output

对于每一个2 x事件,输出对应的答案占一行。

Sample input and output

Sample Input Sample Output
5 3
2 2
0 3
2 2
5
2

解题报告

首先说点题外话。。这题因为数据比较水,因此暴力是可以AC的。。并且跑的还比线段树快。。

当然这题我用的既不是线段树,也不是暴力。。而是set,采用的插入活人线段。。。。跑了500ms+,之后听某哥们说插死人更快。。。瞬间就纠结了

注意更新时情况较多,需一一分析(很麻烦).....

  1 #include <iostream>
  2 #include <cstring>
  3 #include <algorithm>
  4 #include <set>
  5 using namespace std;
  6 const int maxn = 1e5+50;
  7 bool live[maxn];
  8
  9 typedef struct data
 10 {
 11 int l,r;
 12 friend bool operator < (const data&x , const data&y)
 13 {
 14   return x.l  < y.l;
 15 }
 16 data(const int& l, const int& r)
 17 {
 18   this->l = l , this->r = r;
 19 }
 20 };
 21
 22 set<data>List;
 23
 24
 25
 26
 27
 28 int main(int argc,char *argv[])
 29 {
 30   int n,m;
 31   scanf("%d%d",&n,&m);
 32   memset(live,true,sizeof(live));
 33   List.insert(data(1,n));
 34   while(m--)
 35    {
 36          int x,y;
 37          scanf("%d%d",&x,&y);
 38          if (!x)
 39           {
 40                 if (!live[y])  //已经死亡还死。。。不操作了
 41                  continue;
 42                 live[y] = false;
 43                 set<data>::iterator it = List.upper_bound(data(y,0));
 44                 it--;
 45                 int getl = it->l;
 46                 int getr = it->r;
 47                 List.erase(it);
 48                 if (getl == y && getr == y)
 49                  continue;
 50                 if (getl == y)
 51                  List.insert(data(y+1,getr));
 52                 else if(getr == y)
 53                  List.insert(data(getl,getr-1));
 54                 else
 55                  {
 56                       List.insert(data(getl,y-1));
 57                       List.insert(data(y+1,getr));
 58            }
 59        }
 60       else if(x == 1)
 61        {
 62              if (live[y]) //已经活了没必要再复活。。
 63               continue;
 64              live[y] = true;
 65              if (List.size() == 0)
 66               {
 67                     List.insert(data(y,y));
 68                     continue;
 69            }
 70              set<data>::iterator it = List.upper_bound(data(y,0));
 71              it--;
 72              if (List.size() == 1)
 73               {
 74                     if (it == List.end())
 75                      {
 76                           it++;
 77                           if(it->l == y+1)
 78                            {
 79                                 int r = it->r;
 80                                 List.erase(it);
 81                                 List.insert(data(y,r));
 82                   }
 83                  else
 84                   List.insert(data(y,y));
 85                }
 86               else
 87                {
 88                      if (it->r+1 == y)
 89                       {
 90                             int l = it->l;
 91                             List.erase(it);
 92                             List.insert(data(l,y));
 93                    }
 94                    else
 95                      List.insert(data(y,y));
 96                }
 97            }
 98           if (List.size() >= 2)
 99            {
100                  set<data>::iterator it2 = it;
101                  it2++;
102                  if ( it2 != List.end() && it->r + 1 == y && y+1 == it2->l)
103                   {
104                         int l = it->l , r = it2->r ;
105                         List.erase(it);
106                         List.erase(it2);
107                         List.insert(data(l,r));
108                }
109               else if( it!= List.end()&& it->r + 1 == y)
110                {
111                          int l = it->l;
112                           List.erase(it);
113                           List.insert(data(l,y));
114                }
115               else if(it2!= List.end() && it2->l == y+1)
116                {
117                        int r = it2->r;
118                        List.erase(it2);
119                        List.insert(data(y,r));
120                }
121               else
122                    List.insert(data(y,y));
123            }
124        }
125       else
126        {
127              if (!live[y])  //已经死亡
128               {
129                     cout << 0 << endl;
130                     continue;
131            }
132           set<data>::iterator it = List.upper_bound(data(y,0));
133           it--;
134           cout << it->r - it->l + 1 << endl;
135        }
136    }
137   return 0;
138 }
时间: 2024-10-24 11:42:44

UESTC_秋实大哥与战争 2015 UESTC Training for Data Structures<Problem D>的相关文章

UESTC_秋实大哥与快餐店 2015 UESTC Training for Data Structures&lt;Problem C&gt;

C - 秋实大哥与快餐店 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 朝为田舍郎,暮登天子堂.秋实大哥从小就怀抱有远大的理想,所以他开了一家快餐店. 秋实大哥根据菜的口感,给每一道菜一个唯一的CID,同时对于前来的客人,根据他们的口味喜好,秋实大哥会给每一个客人一个PID. 对于一个标号为PID的客人,他对标号为CID的菜的喜爱程度为PID∧CI

UESTC_秋实大哥打游戏 2015 UESTC Training for Data Structures&lt;Problem H&gt;

H - 秋实大哥打游戏 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status ”也许人生就是游戏,你却执意耕耘着春秋.” —— 秋实大哥叹道. 秋实大哥是一个喜欢玩游戏的人,相较于其他种类的游戏,秋实大哥更喜欢自由开放的沙盒游戏,尤其是minecraft. 现在,秋实大哥发现了N个独立的小岛(编号1,2,3.....N),于是他要把这些小岛连起来. 每一次

UESTC_秋实大哥去打工 2015 UESTC Training for Data Structures&lt;Problem G&gt;

G - 秋实大哥去打工 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 天行健,君子以自强不息.地势坤,君子以厚德载物. 天天过节的秋实大哥又要过节了,于是他要给心爱的妹子买礼物.但由于最近秋实大哥手头拮据,身为一个男人,他决定去打工! 秋实大哥来到一家广告公司.现在有n块矩形墙从左至右紧密排列,每一块高为Hi,宽为Wi. 公司要求秋实大哥找出一块最

UESTC_秋实大哥与家 2015 UESTC Training for Data Structures&lt;Problem E&gt;

E - 秋实大哥与家 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 秋实大哥是一个顾家的男人,他认为人生就是旅途,不管我们漂到哪,最终还是会回到温暖的地方——家. 所以他买了很多家具. 秋实大哥的家可以看成一个W×H的矩阵,每一件家具可以看成一个矩形,他们放置在秋实大哥的家里,相互之间没有重叠. 现在秋实大哥购置了一个新的大小为1×M的家具,秋实大

UESTC_秋实大哥与花 2015 UESTC Training for Data Structures&lt;Problem B&gt;

B - 秋实大哥与花 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 秋实大哥是一个儒雅之人,昼听笙歌夜醉眠,若非月下即花前. 所以秋实大哥精心照料了很多花朵.现在所有的花朵排成了一行,每朵花有一个愉悦值. 秋实大哥每天要对着某一段连续的花朵歌唱,然后这些花朵的愉悦值都会增加一个相同的值v(v可能为负). 同时他想知道每次他唱完歌后这一段连续的花朵的

UESTC_秋实大哥与小朋友 2015 UESTC Training for Data Structures&lt;Problem A&gt;

A - 秋实大哥与小朋友 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 秋实大哥以周济天下,锄强扶弱为己任,他常对天长叹:安得广厦千万间,大庇天下寒士俱欢颜. 所以今天他又在给一群小朋友发糖吃. 他让所有的小朋友排成一行,从左到右标号.在接下去的时间中,他有时会给一段区间的小朋友每人v颗糖,有时会问第x个小朋友手里有几颗糖. 这对于没上过学的孩子来

UESTC_秋实大哥搞算数 2015 UESTC Training for Data Structures&lt;Problem N&gt;

N - 秋实大哥搞算数 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 秋实大哥大学物理挂科了,于是在下学期的前两周的某一天要悲剧的补考.为了不给学校的挖掘机大楼做贡献,秋实大哥决定在假期里努力复习.当然,良好的计算能力也是非常必要的,毕竟是涉及计算自己做多少分的题能够通过考试的问题.现在他给自己出了一大堆长长的只有涉及整形四则运算式子,然后埋头计算

UESTC_秋实大哥掰手指 2015 UESTC Training for Dynamic Programming&lt;Problem B&gt;

B - 秋实大哥掰手指 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 2048/1024KB (Java/Others) Submit Status 秋实大哥发现数据结构专题出到了N题,但是他一时算不出来已经有了几道题,他就萌萌地掰手指数. 这个时候他发现,虽然人们根据手指数创造了十进制数,但是两只手同时能表达的数是0-10一共十一个数字. 这样,他觉得如果用手指表现十进制数,同一个十进制数就会有很多种不同的表现方法. 比如,11

UESTC_秋实大哥下棋 2015 UESTC Training for Data Structures&lt;Problem I&gt;

I - 秋实大哥下棋 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 胜负胸中料已明,又从堂上出奇兵.秋实大哥是一个下棋好手,独孤求败的他觉得下棋已经无法满足他了,他开始研究一种新的玩法. 在一个n×m的棋盘上,放置了k个车,并且他在棋盘上标出了q个矩形,表示矩形内部是战略要地. 秋实大哥要求一个矩形内的每一个格子,都至少能被一辆在矩形内的车攻击到,