ACM-ICPC 2018 沈阳赛区现场赛 E. The Kouga Ninja Scrolls (切比雪夫距离+线段树)
题目链接:
题意:在二维平面上有 n 个人,每个人有一个位置(xi, yi)和门派 ci,m 个操作:①改变第 k 个人的位置;②改变第 k 个人的门派;③询问区间[l,r]之间不同门派的两个人的最大曼哈顿距离。
题解:首先需要将曼哈顿距离转化成切比雪夫距离(不懂戳https://www.cnblogs.com/zwfymqz/p/8253530.html),然后用线段树维护一个区间内两个不同门派 x 和 y 的最大最小和次大次小值即可。(维护次大/次小值是因为若区间内的最大值和最小值的人是同一个门派的话则不能进行比较)(代码写的很丑,建议理解做法后自己写一个...
1 #include <bits/stdc++.h> 2 using namespace std; 3 #define ll long long 4 #define ull unsigned long long 5 #define mst(a,b) memset((a),(b),sizeof(a)) 6 #define mp(a,b) make_pair(a,b) 7 #define pi acos(-1) 8 #define pii pair<int,int> 9 #define pb push_back 10 #define fi first 11 #define se second 12 const int INF = 0x3f3f3f3f; 13 const double eps = 1e-6; 14 const int MAXN = 1e5 + 10; 15 const int MAXM = 1e7 + 10; 16 const ll mod = 1e9 + 7; 17 18 ll x[MAXN],y[MAXN]; 19 int c[MAXN]; 20 21 struct node { 22 pair<ll,int> mxx[2], mnx[2]; 23 pair<ll,int> mxy[2], mny[2]; 24 }st[MAXN<<2]; 25 26 void pushup(int rt) { 27 st[rt] = st[rt<<1]; 28 if(st[rt].mxx[0].se == -1) st[rt].mxx[0] = st[rt<<1|1].mxx[0], st[rt].mxx[1] = st[rt<<1|1].mxx[1]; 29 else if(st[rt<<1|1].mxx[0] >= st[rt].mxx[0]) { 30 if(st[rt<<1|1].mxx[0].se != st[rt].mxx[0].se) { 31 st[rt].mxx[1] = st[rt].mxx[0], st[rt].mxx[0] = st[rt<<1|1].mxx[0]; 32 if(st[rt<<1|1].mxx[1].se != -1 && st[rt<<1|1].mxx[1].se != st[rt].mxx[0].se && st[rt<<1|1].mxx[1].fi >= st[rt].mxx[1].fi) 33 st[rt].mxx[1] = st[rt<<1|1].mxx[1]; 34 } else { 35 st[rt].mxx[0] = st[rt<<1|1].mxx[0]; 36 if(st[rt<<1|1].mxx[1].se != -1 && st[rt<<1|1].mxx[1].se != st[rt].mxx[0].se && st[rt<<1|1].mxx[1].fi >= st[rt].mxx[1].fi) 37 st[rt].mxx[1] = st[rt<<1|1].mxx[1]; 38 } 39 } else { 40 if(st[rt<<1|1].mxx[0].se != st[rt].mxx[0].se && st[rt<<1|1].mxx[0].fi >= st[rt].mxx[1].fi) 41 st[rt].mxx[1] = st[rt<<1|1].mxx[0]; 42 else if(st[rt<<1|1].mxx[1].se != -1 && st[rt<<1|1].mxx[1].se != st[rt].mxx[0].se && st[rt<<1|1].mxx[1].fi >= st[rt].mxx[1].fi) 43 st[rt].mxx[1] = st[rt<<1|1].mxx[1]; 44 } 45 //mnx 46 if(st[rt].mnx[0].se == -1) st[rt].mnx[0] = st[rt<<1|1].mnx[0], st[rt].mnx[1] = st[rt<<1|1].mnx[1]; 47 else if(st[rt<<1|1].mnx[0] <= st[rt].mnx[0]) { 48 if(st[rt<<1|1].mnx[0].se != st[rt].mnx[0].se) { 49 st[rt].mnx[1] = st[rt].mnx[0], st[rt].mnx[0] = st[rt<<1|1].mnx[0]; 50 if(st[rt<<1|1].mnx[1].se != -1 && st[rt<<1|1].mnx[1].se != st[rt].mnx[0].se && st[rt<<1|1].mnx[1].fi <= st[rt].mnx[1].fi) 51 st[rt].mnx[1] = st[rt<<1|1].mnx[1]; 52 } else { 53 st[rt].mnx[0] = st[rt<<1|1].mnx[0]; 54 if(st[rt<<1|1].mnx[1].se != -1 && st[rt<<1|1].mnx[1].se != st[rt].mnx[0].se && st[rt<<1|1].mnx[1].fi <= st[rt].mnx[1].fi) 55 st[rt].mnx[1] = st[rt<<1|1].mnx[1]; 56 } 57 } else { 58 if(st[rt<<1|1].mnx[0].se != st[rt].mnx[0].se && st[rt<<1|1].mnx[0].fi <= st[rt].mnx[1].fi) 59 st[rt].mnx[1] = st[rt<<1|1].mnx[0]; 60 else if(st[rt<<1|1].mnx[1].se != -1 && st[rt<<1|1].mnx[1].se != st[rt].mnx[0].se && st[rt<<1|1].mnx[1].fi <= st[rt].mnx[1].fi) 61 st[rt].mnx[1] = st[rt<<1|1].mnx[1]; 62 } 63 //mxy 64 if(st[rt].mxy[0].se == -1) st[rt].mxy[0] = st[rt<<1|1].mxy[0], st[rt].mxy[1] = st[rt<<1|1].mxy[1]; 65 else if(st[rt<<1|1].mxy[0] >= st[rt].mxy[0]) { 66 if(st[rt<<1|1].mxy[0].se != st[rt].mxy[0].se) { 67 st[rt].mxy[1] = st[rt].mxy[0], st[rt].mxy[0] = st[rt<<1|1].mxy[0]; 68 if(st[rt<<1|1].mxy[1].se != -1 && st[rt<<1|1].mxy[1].se != st[rt].mxy[0].se && st[rt<<1|1].mxy[1].fi >= st[rt].mxy[1].fi) 69 st[rt].mxy[1] = st[rt<<1|1].mxy[1]; 70 } else { 71 st[rt].mxy[0] = st[rt<<1|1].mxy[0]; 72 if(st[rt<<1|1].mxy[1].se != -1 && st[rt<<1|1].mxy[1].se != st[rt].mxy[0].se && st[rt<<1|1].mxy[1].fi >= st[rt].mxy[1].fi) 73 st[rt].mxy[1] = st[rt<<1|1].mxy[1]; 74 } 75 } else { 76 if(st[rt<<1|1].mxy[0].se != st[rt].mxy[0].se && st[rt<<1|1].mxy[0].fi >= st[rt].mxy[1].fi) 77 st[rt].mxy[1] = st[rt<<1|1].mxy[0]; 78 else if(st[rt<<1|1].mxy[1].se != -1 && st[rt<<1|1].mxy[1].se != st[rt].mxy[0].se && st[rt<<1|1].mxy[1].fi >= st[rt].mxy[1].fi) 79 st[rt].mxy[1] = st[rt<<1|1].mxy[1]; 80 } 81 //mny 82 if(st[rt].mny[0].se == -1) st[rt].mny[0] = st[rt<<1|1].mny[0], st[rt].mny[1] = st[rt<<1|1].mny[1]; 83 else if(st[rt<<1|1].mny[0] <= st[rt].mny[0]) { 84 if(st[rt<<1|1].mny[0].se != st[rt].mny[0].se) { 85 st[rt].mny[1] = st[rt].mny[0], st[rt].mny[0] = st[rt<<1|1].mny[0]; 86 if(st[rt<<1|1].mny[1].se != -1 && st[rt<<1|1].mny[1].se != st[rt].mny[0].se && st[rt<<1|1].mny[1].fi <= st[rt].mny[1].fi) 87 st[rt].mny[1] = st[rt<<1|1].mny[1]; 88 } else { 89 st[rt].mny[0] = st[rt<<1|1].mny[0]; 90 if(st[rt<<1|1].mny[1].se != -1 && st[rt<<1|1].mny[1].se != st[rt].mny[0].se && st[rt<<1|1].mny[1].fi <= st[rt].mny[1].fi) 91 st[rt].mny[1] = st[rt<<1|1].mny[1]; 92 } 93 } else { 94 if(st[rt<<1|1].mny[0].se != st[rt].mny[0].se && st[rt<<1|1].mny[0].fi <= st[rt].mny[1].fi) 95 st[rt].mny[1] = st[rt<<1|1].mny[0]; 96 else if(st[rt<<1|1].mny[1].se != -1 && st[rt<<1|1].mny[1].se != st[rt].mny[0].se && st[rt<<1|1].mny[1].fi <= st[rt].mny[1].fi) 97 st[rt].mny[1] = st[rt<<1|1].mny[1]; 98 } 99 } 100 101 void build(int rt,int l,int r) { 102 if(l == r) { 103 st[rt].mxx[0].fi = st[rt].mnx[0].fi = x[l], st[rt].mxx[0].se = st[rt].mnx[0].se = c[l]; 104 st[rt].mxx[1].se = st[rt].mnx[1].se = -1; 105 st[rt].mxy[0].fi = st[rt].mny[0].fi = y[l], st[rt].mxy[0].se = st[rt].mny[0].se = c[l]; 106 st[rt].mxy[1].se = st[rt].mny[1].se = -1; 107 return ; 108 } 109 int mid = (l + r) >> 1; 110 build(rt<<1,l,mid); 111 build(rt<<1|1,mid + 1,r); 112 pushup(rt); 113 } 114 115 void update(int rt,int l,int r,int pos) { 116 if(l == r) { 117 st[rt].mxx[0].fi = st[rt].mnx[0].fi = x[l], st[rt].mxx[0].se = st[rt].mnx[0].se = c[l]; 118 st[rt].mxx[1].se = st[rt].mnx[1].se = -1; 119 st[rt].mxy[0].fi = st[rt].mny[0].fi = y[l], st[rt].mxy[0].se = st[rt].mny[0].se = c[l]; 120 st[rt].mxy[1].se = st[rt].mny[1].se = -1; 121 return ; 122 } 123 int mid = (l + r) >> 1; 124 if(pos <= mid) update(rt<<1,l,mid,pos); 125 else update(rt<<1|1,mid + 1,r,pos); 126 pushup(rt); 127 } 128 129 node ans; 130 131 void query(int rt,int l,int r,int ql,int qr) { 132 if(ql <= l && qr >= r) { 133 //mxx 134 if(ans.mxx[0].se == -1) ans.mxx[0] = st[rt].mxx[0], ans.mxx[1] = st[rt].mxx[1]; 135 else if(st[rt].mxx[0] >= ans.mxx[0]) { 136 if(st[rt].mxx[0].se != ans.mxx[0].se) { 137 ans.mxx[1] = ans.mxx[0], ans.mxx[0] = st[rt].mxx[0]; 138 if(st[rt].mxx[1].se != -1 && st[rt].mxx[1].se != ans.mxx[0].se && st[rt].mxx[1].fi >= ans.mxx[1].fi) 139 ans.mxx[1] = st[rt].mxx[1]; 140 } else { 141 ans.mxx[0] = st[rt].mxx[0]; 142 if(st[rt].mxx[1].se != -1 && st[rt].mxx[1].se != ans.mxx[0].se && st[rt].mxx[1].fi >= ans.mxx[1].fi) 143 ans.mxx[1] = st[rt].mxx[1]; 144 } 145 } else { 146 if(st[rt].mxx[0].se != ans.mxx[0].se && st[rt].mxx[0].fi >= ans.mxx[1].fi) 147 ans.mxx[1] = st[rt].mxx[0]; 148 else if(st[rt].mxx[1].se != -1 && st[rt].mxx[1].se != ans.mxx[0].se && st[rt].mxx[1].fi >= ans.mxx[1].fi) 149 ans.mxx[1] = st[rt].mxx[1]; 150 } 151 //mnx 152 if(ans.mnx[0].se == -1) ans.mnx[0] = st[rt].mnx[0], ans.mnx[1] = st[rt].mnx[1]; 153 else if(st[rt].mnx[0] <= ans.mnx[0]) { 154 if(st[rt].mnx[0].se != ans.mnx[0].se) { 155 ans.mnx[1] = ans.mnx[0], ans.mnx[0] = st[rt].mnx[0]; 156 if(st[rt].mnx[1].se != -1 && st[rt].mnx[1].se != ans.mnx[0].se && st[rt].mnx[1].fi <= ans.mnx[1].fi) 157 ans.mnx[1] = st[rt].mnx[1]; 158 } else { 159 ans.mnx[0] = st[rt].mnx[0]; 160 if(st[rt].mnx[1].se != -1 && st[rt].mnx[1].se != ans.mnx[0].se && st[rt].mnx[1].fi <= ans.mnx[1].fi) 161 ans.mnx[1] = st[rt].mnx[1]; 162 } 163 } else { 164 if(st[rt].mnx[0].se != ans.mnx[0].se && st[rt].mnx[0].fi <= ans.mnx[1].fi) 165 ans.mnx[1] = st[rt].mnx[0]; 166 else if(st[rt].mnx[1].se != -1 && st[rt].mnx[1].se != ans.mnx[0].se && st[rt].mnx[1].fi <= ans.mnx[1].fi) 167 ans.mnx[1] = st[rt].mnx[1]; 168 } 169 //mxy 170 if(ans.mxy[0].se == -1) ans.mxy[0] = st[rt].mxy[0], ans.mxy[1] = st[rt].mxy[1]; 171 else if(st[rt].mxy[0] >= ans.mxy[0]) { 172 if(st[rt].mxy[0].se != ans.mxy[0].se) { 173 ans.mxy[1] = ans.mxy[0], ans.mxy[0] = st[rt].mxy[0]; 174 if(st[rt].mxy[1].se != -1 && st[rt].mxy[1].se != ans.mxy[0].se && st[rt].mxy[1].fi >= ans.mxy[1].fi) 175 ans.mxy[1] = st[rt].mxy[1]; 176 } else { 177 ans.mxy[0] = st[rt].mxy[0]; 178 if(st[rt].mxy[1].se != -1 && st[rt].mxy[1].se != ans.mxy[0].se && st[rt].mxy[1].fi >= ans.mxy[1].fi) 179 ans.mxy[1] = st[rt].mxy[1]; 180 } 181 } else { 182 if(st[rt].mxy[0].se != ans.mxy[0].se && st[rt].mxy[0].fi >= ans.mxy[1].fi) 183 ans.mxy[1] = st[rt].mxy[0]; 184 else if(st[rt].mxy[1].se != -1 && st[rt].mxy[1].se != ans.mxy[0].se && st[rt].mxy[1].fi >= ans.mxy[1].fi) 185 ans.mxy[1] = st[rt].mxy[1]; 186 } 187 //mny 188 if(ans.mny[0].se == -1) ans.mny[0] = st[rt].mny[0], ans.mny[1] = st[rt].mny[1]; 189 else if(st[rt].mny[0] <= ans.mny[0]) { 190 if(st[rt].mny[0].se != ans.mny[0].se) { 191 ans.mny[1] = ans.mny[0], ans.mny[0] = st[rt].mny[0]; 192 if(st[rt].mny[1].se != -1 && st[rt].mny[1].se != ans.mny[0].se && st[rt].mny[1].fi <= ans.mny[1].fi) 193 ans.mny[1] = st[rt].mny[1]; 194 } else { 195 ans.mny[0] = st[rt].mny[0]; 196 if(st[rt].mny[1].se != -1 && st[rt].mny[1].se != ans.mny[0].se && st[rt].mny[1].fi <= ans.mny[1].fi) 197 ans.mny[1] = st[rt].mny[1]; 198 } 199 } else { 200 if(st[rt].mny[0].se != ans.mny[0].se && st[rt].mny[0].fi <= ans.mny[1].fi) 201 ans.mny[1] = st[rt].mny[0]; 202 else if(st[rt].mny[1].se != -1 && st[rt].mny[1].se != ans.mny[0].se && st[rt].mny[1].fi <= ans.mny[1].fi) 203 ans.mny[1] = st[rt].mny[1]; 204 } 205 return ; 206 } 207 int mid = (l + r) >> 1; 208 if(qr <= mid) query(rt<<1,l,mid,ql,qr); 209 else if(ql > mid) query(rt<<1|1,mid + 1,r,ql,qr); 210 else { 211 query(rt<<1,l,mid,ql,mid); 212 query(rt<<1|1,mid + 1,r,mid + 1,qr); 213 } 214 } 215 216 int main() { 217 #ifdef local 218 freopen("data.txt", "r", stdin); 219 // freopen("data.txt", "w", stdout); 220 #endif 221 int cas = 1; 222 int t; 223 scanf("%d",&t); 224 while(t--) { 225 printf("Case #%d:\n",cas++); 226 int n,m; 227 scanf("%d%d",&n,&m); 228 for(int i = 1; i <= n; i++) { 229 ll x0,y0; 230 scanf("%lld%lld%d",&x0,&y0,&c[i]); 231 x[i] = x0 + y0, y[i] = x0 - y0; 232 } 233 build(1,1,n); 234 while(m--) { 235 int op; 236 scanf("%d",&op); 237 if(op == 1) { 238 int k; 239 ll x0,y0; 240 scanf("%d%lld%lld",&k,&x0,&y0); 241 x[k] += x0 + y0, y[k] += x0 - y0; 242 update(1,1,n,k); 243 } else if(op == 2) { 244 int k,col; 245 scanf("%d%d",&k,&col); 246 c[k] = col; 247 update(1,1,n,k); 248 } else if(op == 3) { 249 int l,r; 250 scanf("%d%d",&l,&r); 251 252 for(int i = 0; i < 2; i++) { 253 ans.mxx[i].se = ans.mnx[i].se = -1; 254 ans.mxy[i].se = ans.mny[i].se = -1; 255 } 256 query(1,1,n,l,r); 257 ll out = 0; 258 //x 259 if(ans.mxx[0].se != -1) { 260 if(ans.mxx[1].se != -1 && ans.mxx[1].se != ans.mxx[0].se) 261 out = max(out,abs(ans.mxx[0].fi - ans.mxx[1].fi)); 262 if(ans.mnx[0].se != -1 && ans.mnx[0].se != ans.mxx[0].se) 263 out = max(out,abs(ans.mxx[0].fi - ans.mnx[0].fi)); 264 if(ans.mnx[1].se != -1 && ans.mnx[1].se != ans.mxx[0].se) 265 out = max(out,abs(ans.mxx[0].fi - ans.mnx[1].fi)); 266 } 267 if(ans.mxx[1].se != -1) { 268 if(ans.mnx[0].se != -1 && ans.mnx[0].se != ans.mxx[1].se) 269 out = max(out,abs(ans.mxx[1].fi - ans.mnx[0].fi)); 270 if(ans.mnx[1].se != -1 && ans.mnx[1].se != ans.mxx[1].se) 271 out = max(out,abs(ans.mxx[1].fi - ans.mnx[1].fi)); 272 } 273 if(ans.mnx[0].se != -1 && ans.mnx[1].se != -1) 274 out = max(out,abs(ans.mnx[0].fi - ans.mnx[1].fi)); 275 //y 276 if(ans.mxy[0].se != -1) { 277 if(ans.mxy[1].se != -1 && ans.mxy[1].se != ans.mxy[0].se) 278 out = max(out,abs(ans.mxy[0].fi - ans.mxy[1].fi)); 279 if(ans.mny[0].se != -1 && ans.mny[0].se != ans.mxy[0].se) 280 out = max(out,abs(ans.mxy[0].fi - ans.mny[0].fi)); 281 if(ans.mny[1].se != -1 && ans.mny[1].se != ans.mxy[0].se) 282 out = max(out,abs(ans.mxy[0].fi - ans.mny[1].fi)); 283 } 284 if(ans.mxy[1].se != -1) { 285 if(ans.mny[0].se != -1 && ans.mny[0].se != ans.mxy[1].se) 286 out = max(out,abs(ans.mxy[1].fi - ans.mny[0].fi)); 287 if(ans.mny[1].se != -1 && ans.mny[1].se != ans.mxy[1].se) 288 out = max(out,abs(ans.mxy[1].fi - ans.mny[1].fi)); 289 } 290 if(ans.mny[0].se != -1 && ans.mny[1].se != -1) 291 out = max(out,abs(ans.mny[0].fi - ans.mny[1].fi)); 292 printf("%lld\n",out); 293 } 294 } 295 } 296 return 0; 297 }