hdu 4022 Bombing (离散化)
wa了两次,原因是在同一个点可能有多个基地。。。
所以用set 是错误的,应该用multiset
然后因为这道题看到了map+set实现离散化的另外一种写法
我的代码:
1/*************************************************************************
2 > File Name: code/hdoj/4022.cpp
3 > Author: 111qqz
4 > Email: rkz2013@126.com
5 > Created Time: 2015年08月01日 星期六 04时37分20秒
6 ************************************************************************/
7
8#include<iostream>
9#include<iomanip>
10#include<cstdio>
11#include<algorithm>
12#include<cmath>
13#include<cstring>
14#include<string>
15#include<map>
16#include<set>
17#include<queue>
18#include<vector>
19#include<stack>
20#define y0 abc111qqz
21#define y1 hust111qqz
22#define yn hez111qqz
23#define j1 cute111qqz
24#define tm crazy111qqz
25#define lr dying111qqz
26using namespace std;
27#define REP(i, n) for (int i=0;i<int(n);++i)
28typedef long long LL;
29typedef unsigned long long ULL;
30const int N=2E5+7;
31const int inf = 0x7fffffff;
32
33map<int,int>xmap,ymap;
34multiset<int>x[N];
35multiset<int>y[N];
36int main()
37{
38 int n,m;
39 while (scanf("%d %d",&n,&m)!=EOF)
40 {
41 if (n==0&&m==0) break;
42 for ( int i = 1 ; i <= n ; i++)
43 {
44 x[i].clear();
45 y[i].clear();
46 }
47 xmap.clear();
48 ymap.clear();
49 int tx,ty;
50 int cntx=0,cnty=0;
51 for ( int i = 1 ; i <= n ; i++ )
52 {
53 scanf("%d %d",&tx,&ty);
54 if (!xmap[tx]) xmap[tx]=++cntx;
55 if (!ymap[ty]) ymap[ty]=++cnty;
56 x[xmap[tx]].insert(ymap[ty]);
57 y[ymap[ty]].insert(xmap[tx]);
58 }
59 int c,d;
60 set<int>::iterator it;
61 for ( int i = 1; i <= m ; i++ )
62 {
63 scanf("%d %d",&c,&d);
64 if (c==0)
65 {
66 cout<<x[xmap[d]].size()<<endl;
67 for ( it = x[xmap[d]].begin();it!=x[xmap[d]].end();it++)
68 {
69 y[*it].erase(xmap[d]);
70 }
71 x[xmap[d]].clear();
72 }
73 else
74 {
75 cout<<y[ymap[d]].size()<<endl;
76 for ( it =y[ymap[d]].begin();it!=y[ymap[d]].end();it++)
77 {
78 x[*it].erase(ymap[d]);
79
80 }
81 y[ymap[d]].clear();
82 }
83 }
84 printf("\n");
85 }
86
87 return 0;
88}