結果
| 問題 |
No.2687 所により大雨
|
| コンテスト | |
| ユーザー |
tails
|
| 提出日時 | 2024-03-22 11:33:14 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 70 ms / 2,000 ms |
| コード長 | 18,212 bytes |
| コンパイル時間 | 4,449 ms |
| コンパイル使用メモリ | 228,492 KB |
| 実行使用メモリ | 7,040 KB |
| 最終ジャッジ日時 | 2024-09-30 10:33:39 |
| 合計ジャッジ時間 | 5,562 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 25 |
ソースコード
#pragma GCC optimize("Ofast")
#pragma GCC optimize("unroll-loops")
#pragma GCC optimize("inline")
#include<bits/stdc++.h>
#include<sys/time.h>
using namespace std;
template<class T> struct cLtraits_identity{
using type = T;
}
;
template<class T> using cLtraits_try_make_unsigned =
typename conditional<
is_integral<T>::value,
make_unsigned<T>,
cLtraits_identity<T>
>::type;
void*wmem;
char memarr[96000000];
template<class S, class T> inline S chmin(S &a, T b){
if(a>b){
a=b;
}
return a;
}
template<class S, class T> inline S chmax(S &a, T b){
if(a<b){
a=b;
}
return a;
}
template<class S, class T> inline S divup_L(S a, T b){
return (a+b-1)/b;
}
template<class T> inline void walloc1d(T **arr, int x, void **mem = &wmem){
static int skip[16] = {0, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
(*mem) = (void*)( ((char*)(*mem)) + skip[((unsigned long long)(*mem)) & 15] );
(*arr)=(T*)(*mem);
(*mem)=((*arr)+x);
}
template<class T> inline void walloc1d(T **arr, int x1, int x2, void **mem = &wmem){
walloc1d(arr, x2-x1, mem);
(*arr) -= x1;
}
inline int Ilog2_f_L(const int n){
int res;
if(n <= 0){
return -1;
}
res = sizeof(int) * 8 - __builtin_clz(n) - 1;
return res;
}
inline int Ilog2_f_L(const long long n){
int res;
if(n <= 0){
return -1;
}
res = sizeof(long long) * 8 - __builtin_clzll(n) - 1;
return res;
}
template<class T1> void sortI(int N, T1 a[], void *mem = wmem){
sort(a, a+N);
}
template<class T1, class T2> void sortI(int N, T1 a[], T2 b[], void *mem = wmem){
int i;
pair<T1, T2>*arr;
walloc1d(&arr, N, &mem);
for(i=(0);i<(N);i++){
arr[i].first = a[i];
arr[i].second = b[i];
}
sort(arr, arr+N);
for(i=(0);i<(N);i++){
a[i] = arr[i].first;
b[i] = arr[i].second;
}
}
template<class T1, class T2, class T3> void sortI(int N, T1 a[], T2 b[], T3 c[], void *mem = wmem){
int i;
pair<T1, pair<T2, T3> >*arr;
walloc1d(&arr, N, &mem);
for(i=(0);i<(N);i++){
arr[i].first = a[i];
arr[i].second.first = b[i];
arr[i].second.second = c[i];
}
sort(arr, arr+N);
for(i=(0);i<(N);i++){
a[i] = arr[i].first;
b[i] = arr[i].second.first;
c[i] = arr[i].second.second;
}
}
template<class T1, class T2, class T3, class T4> void sortI(int N, T1 a[], T2 b[], T3 c[], T4 d[], void *mem = wmem){
int i;
pair<pair<T1, T2>, pair<T3, T4> >*arr;
walloc1d(&arr, N, &mem);
for(i=(0);i<(N);i++){
arr[i].first.first = a[i];
arr[i].first.second = b[i];
arr[i].second.first = c[i];
arr[i].second.second = d[i];
}
sort(arr, arr+N);
for(i=(0);i<(N);i++){
a[i] = arr[i].first.first;
b[i] = arr[i].first.second;
c[i] = arr[i].second.first;
d[i] = arr[i].second.second;
}
}
template<class T> inline int sort_helper_getbit(T A[]){
return -1;
}
template<> inline int sort_helper_getbit(int A[]){
return sizeof(int)*8;
}
template<> inline int sort_helper_getbit(unsigned A[]){
return sizeof(unsigned)*8;
}
template<> inline int sort_helper_getbit(long long A[]){
return sizeof(long long)*8;
}
template<> inline int sort_helper_getbit(unsigned long long A[]){
return sizeof(unsigned long long)*8;
}
template<> inline int sort_helper_getbit(char A[]){
return sizeof(char)*8;
}
template<class T> void sortA_1_int_L(int N, T A[], void *mem = wmem){
int i;
int j;
int k;
int b;
int s;
int ok;
ok = 1;
for(i=(1);i<(N);i++){
if(A[i-1] > A[i]){
ok = 0;
break;
}
}
if(ok){
return;
}
if(N < 128){
sort(A,A+N);
return;
}
b = sort_helper_getbit(A);
if(b==-1){
sort(A,A+N);
return;
}
T mn;
T mx;
mn = mx = A[0];
for(i=(1);i<(N);i++){
chmin(mn, A[i]);
}
for(i=(1);i<(N);i++){
chmax(mx, A[i]);
}
ok = 1;
if(mn < 0 && mx > 0 && (mn < -N || mx > N)){
ok = 0;
}
if(ok && mx - mn > N){
ok = 0;
}
if(ok){
int*tmp;
walloc1d(&tmp, mx-mn+1, &mem);
for(i=(0);i<(mx-mn+1);i++){
tmp[i] = 0;
}
for(i=(0);i<(N);i++){
tmp[A[i]-mn]++;
}
k = 0;
for(i=(0);i<(mx-mn+1);i++){
while(tmp[i] > 0){
tmp[i]--;
A[k++] = i+mn;
}
}
return;
}
{
typename make_unsigned<T>::type *t[2];
typename make_unsigned<T>::type mask;
typename make_unsigned<T>::type cur;
typename make_unsigned<T>::type one = 1;
T tone = 1;
int*pos;
int nn = 0;
int ss;
s =Ilog2_f_L(N);
if(s > 8){
s = (8 + (s-7)/2);
}
ss = 1;
for(;;){
if(ss >= b){
break;
}
if( mx >= 0 && (tone << (ss-1)) < mx ){
ss++;
continue;
}
if( mn < 0 && -(tone << (ss-1)) >= mn ){
ss++;
continue;
}
break;
}
k =(divup_L(ss,s));
s =(divup_L(ss,k));
mask = 0;
for(i=(0);i<(b);i++){
if(i < s*k){
mask |= one << i;
}
}
t[0] = (typename make_unsigned<T>::type *) A;
walloc1d(&t[1], N, &mem);
walloc1d(&pos, (1<<s)+1, &mem);
for(j=(0);j<(k);j++){
cur = 0;
for(i=(0);i<(b);i++){
if(s*j <= i && i < s*(j+1) && i < b){
cur |= one << i;
}
}
for(i=(0);i<((1<<s)+1);i++){
pos[i] = 0;
}
for(i=(0);i<(N);i++){
pos[((t[nn][i]&cur)>>(s*j))+1]++;
}
for(i=(0);i<((1<<s));i++){
pos[i+1] += pos[i];
}
for(i=(0);i<(N);i++){
t[nn^1][pos[(t[nn][i]&cur)>>(s*j)]++] = t[nn][i];
}
nn ^= 1;
mask ^= cur;
}
if(mn < 0 && mx >= 0){
k = 0;
for(i=(0);i<(N);i++){
if(A[i] < 0){
k++;
}
}
for(i=(0);i<(k);i++){
t[nn^1][i] = t[nn][N-k+i];
}
for(i=(k);i<(N);i++){
t[nn^1][i] = t[nn][i-k];
}
nn ^= 1;
}
if(nn==1){
for(i=(0);i<(N);i++){
t[0][i] = t[1][i];
}
}
return;
}
sort(A, A+N);
}
template<class T> void sortA_1_nonint_L(int N, T A[], void *mem = wmem){
sort(A,A+N);
}
template<class T> void sortA_1_call_L(int N, T A[], void *mem = wmem){
sortA_1_nonint_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, int A[], void *mem){
sortA_1_int_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, unsigned A[], void *mem){
sortA_1_int_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, long long A[], void *mem){
sortA_1_int_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, unsigned long long A[], void *mem){
sortA_1_int_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, char A[], void *mem){
sortA_1_int_L(N, A, mem);
}
template<class T1> void sortA(int N, T1 a[], void *mem = wmem){
sortA_1_call_L(N, a, mem);
}
template<class T1, class T2> void sortA_2_int_L(int N, T1 A[], T2 B[], void *mem = wmem){
int i;
int b_a;
int b_b;
int s1;
int s2;
int so2;
T1 mn1;
T1 mx1;
T2 mn2;
T2 mx2;
typename cLtraits_try_make_unsigned<T1>::type r1;
typename cLtraits_try_make_unsigned<T2>::type r2;
so2 = 1;
for(i=(1);i<(N);i++){
if(A[i-1] > A[i] || (A[i-1]==A[i] && B[i-1] > B[i])){
so2 = 0;
break;
}
}
if(so2){
return;
}
so2 = 1;
for(i=(1);i<(N);i++){
if(A[i-1] > A[i]){
so2 = 0;
break;
}
}
if(so2==1){
int k = 0;
for(i=(1);i<(N);i++){
if(A[i] != A[i-1]){
sortA_1_call_L(i-k, B+k, mem);
k = i;
}
}
sortA_1_call_L(N-k, B+k, mem);
return;
}
if(N < 128){
sortI(N,A,B,mem);
return;
}
b_a = sort_helper_getbit(A);
b_b = sort_helper_getbit(B);
if(b_a == -1 || b_b == -1){
sortI(N,A,B,mem);
return;
}
mn1 = mx1 = A[0];
for(i=(1);i<(N);i++){
chmin(mn1, A[i]);
}
for(i=(1);i<(N);i++){
chmax(mx1, A[i]);
}
mn2 = mx2 = B[0];
for(i=(1);i<(N);i++){
chmin(mn2, B[i]);
}
for(i=(1);i<(N);i++){
chmax(mx2, B[i]);
}
if(mn1 < -4611686016279904256LL || mn2 < -4611686016279904256LL || mx1 > 4611686016279904256LL || mx2 > 4611686016279904256LL || mx1-mn1 > 4611686016279904256LL || mx2-mn2 > 4611686016279904256LL){
sortI(N,A,B,mem);
return;
}
r1 = (typename cLtraits_try_make_unsigned<T1>::type)(mx1) - (typename cLtraits_try_make_unsigned<T1>::type)(mn1);
r2 = (typename cLtraits_try_make_unsigned<T2>::type)(mx2) - (typename cLtraits_try_make_unsigned<T2>::type)(mn2);
if(r1 == 0){
sortA_1_call_L(N, B, mem);
return;
}
if(r2 == 0){
sortA_1_call_L(N, A, mem);
return;
}
if(r1 <= N){
so2 = 1;
for(i=(1);i<(N);i++){
if(B[i-1] > B[i]){
so2 = 0;
break;
}
}
if(so2 == 1){
T1*aa;
T2*bb;
int*pos;
int k;
walloc1d(&aa,N,&mem);
walloc1d(&bb,N,&mem);
walloc1d(&pos,r1+2,&mem);
for(i=(0);i<(r1+2);i++){
pos[i] = 0;
}
for(i=(0);i<(N);i++){
aa[i] = A[i];
}
for(i=(0);i<(N);i++){
bb[i] = B[i];
}
for(i=(0);i<(N);i++){
pos[(typename cLtraits_try_make_unsigned<T1>::type)((typename cLtraits_try_make_unsigned<T1>::type)aa[i]-(typename cLtraits_try_make_unsigned<T1>::type)mn1)+1]++;
}
for(i=(1);i<(r1+2);i++){
pos[i] += pos[i-1];
}
for(i=(0);i<(N);i++){
k = pos[(typename cLtraits_try_make_unsigned<T1>::type)((typename cLtraits_try_make_unsigned<T1>::type)aa[i]-(typename cLtraits_try_make_unsigned<T1>::type)mn1)+0]++;
A[k] = aa[i];
B[k] = bb[i];
}
return;
}
}
s1 = s2 = 1;
while( s1 < 64 && r1 >= (1ULL<<s1) ){
s1++;
}
while( s2 < 64 && r2 >= (1ULL<<s2) ){
s2++;
}
if(s1 + s2 <= 32){
unsigned*tmp;
walloc1d(&tmp,N,&mem);
for(i=(0);i<(N);i++){
tmp[i] = (((unsigned)((int)A[i]-(int)mn1)) << s2) | ((unsigned)((int)B[i]-(int)mn2));
}
sortA_1_call_L(N, tmp, mem);
for(i=(0);i<(N);i++){
A[i] = ((int)(tmp[i] >> s2)) + ((int)mn1);
B[i] = ((int)(tmp[i] & ((1U<<s2)-1))) + ((int)mn2);
}
return;
}
if(s1 + s2 <= 64){
unsigned long long*tmp;
walloc1d(&tmp,N,&mem);
for(i=(0);i<(N);i++){
tmp[i] = (((unsigned long long)((long long)A[i]-(long long)mn1)) << s2) | ((unsigned long long)((long long)B[i]-(long long)mn2));
}
sortA_1_call_L(N, tmp, mem);
for(i=(0);i<(N);i++){
A[i] = ((long long)(tmp[i] >> s2)) + ((long long)mn1);
B[i] = ((long long)(tmp[i] & ((1ULL<<s2)-1))) + ((long long)mn2);
}
return;
}
sortI(N,A,B,mem);
}
template<class T1, class T2> void sortA_2_nonint_L(int N, T1 A[], T2 B[], void *mem = wmem){
sortI(N,A,B,mem);
}
template<class T1, class T2> void sortA_2_call_L(int N, T1 A[], T2 B[], void *mem = wmem){
sortA_2_nonint_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, int A[], T2 B[], void *mem){
sortA_2_int_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, unsigned A[], T2 B[], void *mem){
sortA_2_int_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, long long A[], T2 B[], void *mem){
sortA_2_int_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, unsigned long long A[], T2 B[], void *mem){
sortA_2_int_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, char A[], T2 B[], void *mem){
sortA_2_int_L(N, A, B, mem);
}
template<class T1, class T2> void sortA(int N, T1 a[], T2 b[], void *mem = wmem){
sortA_2_call_L(N, a, b, mem);
}
template<class T1, class T2, class T3> void sortA(int N, T1 a[], T2 b[], T3 c[], void *mem = wmem){
int i;
pair<T1, pair<T2, T3> >*arr;
walloc1d(&arr, N, &mem);
for(i=(0);i<(N);i++){
arr[i].first = a[i];
arr[i].second.first = b[i];
arr[i].second.second = c[i];
}
sort(arr, arr+N);
for(i=(0);i<(N);i++){
a[i] = arr[i].first;
b[i] = arr[i].second.first;
c[i] = arr[i].second.second;
}
}
template<class T1, class T2, class T3, class T4> void sortA(int N, T1 a[], T2 b[], T3 c[], T4 d[], void *mem = wmem){
int i;
pair<pair<T1, T2>, pair<T3, T4> >*arr;
walloc1d(&arr, N, &mem);
for(i=(0);i<(N);i++){
arr[i].first.first = a[i];
arr[i].first.second = b[i];
arr[i].second.first = c[i];
arr[i].second.second = d[i];
}
sort(arr, arr+N);
for(i=(0);i<(N);i++){
a[i] = arr[i].first.first;
b[i] = arr[i].first.second;
c[i] = arr[i].second.first;
d[i] = arr[i].second.second;
}
}
struct Timer{
double x;
double gettimeofday_sec(void){
timeval t;
gettimeofday(&t, 0);
return t.tv_sec + t.tv_usec * 1e-6;
}
void set(void){
x = gettimeofday_sec();
}
double get(void){
return gettimeofday_sec() - x;
}
}
;
inline int my_getchar_unlocked(){
static char buf[1048576];
static int s = 1048576;
static int e = 1048576;
if(s == e && e == 1048576){
e = fread_unlocked(buf, 1, 1048576, stdin);
s = 0;
}
if(s == e){
return EOF;
}
return buf[s++];
}
inline void rd(int &x){
int k;
int m=0;
x=0;
for(;;){
k = my_getchar_unlocked();
if(k=='-'){
m=1;
break;
}
if('0'<=k&&k<='9'){
x=k-'0';
break;
}
}
for(;;){
k = my_getchar_unlocked();
if(k<'0'||k>'9'){
break;
}
x=x*10+k-'0';
}
if(m){
x=-x;
}
}
inline void rd(long long &x){
int k;
int m=0;
x=0;
for(;;){
k = my_getchar_unlocked();
if(k=='-'){
m=1;
break;
}
if('0'<=k&&k<='9'){
x=k-'0';
break;
}
}
for(;;){
k = my_getchar_unlocked();
if(k<'0'||k>'9'){
break;
}
x=x*10+k-'0';
}
if(m){
x=-x;
}
}
struct MY_WRITER{
char buf[1048576];
int s;
int e;
MY_WRITER(){
s = 0;
e = 1048576;
}
~MY_WRITER(){
if(s){
fwrite_unlocked(buf, 1, s, stdout);
}
}
}
;
MY_WRITER MY_WRITER_VAR;
void my_putchar_unlocked(int a){
if(MY_WRITER_VAR.s == MY_WRITER_VAR.e){
fwrite_unlocked(MY_WRITER_VAR.buf, 1, MY_WRITER_VAR.s, stdout);
MY_WRITER_VAR.s = 0;
}
MY_WRITER_VAR.buf[MY_WRITER_VAR.s++] = a;
}
template<class T> inline void wt_L(vector<T> x);
template<class T> inline void wt_L(set<T> x);
template<class T> inline void wt_L(multiset<T> x);
template<class T1, class T2> inline void wt_L(pair<T1,T2> x);
inline void wt_L(char a){
my_putchar_unlocked(a);
}
inline void wt_L(int x){
int s=0;
int m=0;
char f[10];
if(x<0){
m=1;
x=-x;
}
while(x){
f[s++]=x%10;
x/=10;
}
if(!s){
f[s++]=0;
}
if(m){
my_putchar_unlocked('-');
}
while(s--){
my_putchar_unlocked(f[s]+'0');
}
}
inline void wt_L(unsigned x){
int s=0;
char f[10];
while(x){
f[s++]=x%10;
x/=10;
}
if(!s){
f[s++]=0;
}
while(s--){
my_putchar_unlocked(f[s]+'0');
}
}
inline void wt_L(long long x){
int s=0;
int m=0;
char f[20];
if(x<0){
m=1;
x=-x;
}
while(x){
f[s++]=x%10;
x/=10;
}
if(!s){
f[s++]=0;
}
if(m){
my_putchar_unlocked('-');
}
while(s--){
my_putchar_unlocked(f[s]+'0');
}
}
inline void wt_L(unsigned long long x){
int s=0;
char f[21];
while(x){
f[s++]=x%10;
x/=10;
}
if(!s){
f[s++]=0;
}
while(s--){
my_putchar_unlocked(f[s]+'0');
}
}
int WRITER_DOUBLE_DIGIT = 15;
inline int writerDigit_double(){
return WRITER_DOUBLE_DIGIT;
}
inline void writerDigit_double(int d){
WRITER_DOUBLE_DIGIT = d;
}
inline void wt_L(double x){
const int d = WRITER_DOUBLE_DIGIT;
int k;
int r;
double v;
if(x!=x || (x==x+1 && x==2*x)){
my_putchar_unlocked('E');
my_putchar_unlocked('r');
my_putchar_unlocked('r');
return;
}
if(x < 0){
my_putchar_unlocked('-');
x = -x;
}
x += 0.5 * pow(0.1, d);
r = 0;
v = 1;
while(x >= 10*v){
v *= 10;
r++;
}
while(r >= 0){
r--;
k = floor(x / v);
if(k >= 10){
k = 9;
}
if(k <= -1){
k = 0;
}
x -= k * v;
v *= 0.1;
my_putchar_unlocked(k + '0');
}
if(d > 0){
my_putchar_unlocked('.');
v = 1;
for(r=(0);r<(d);r++){
v *= 0.1;
k = floor(x / v);
if(k >= 10){
k = 9;
}
if(k <= -1){
k = 0;
}
x -= k * v;
my_putchar_unlocked(k + '0');
}
}
}
inline void wt_L(const char c[]){
int i=0;
for(i=0;c[i]!='\0';i++){
my_putchar_unlocked(c[i]);
}
}
inline void wt_L(string &x){
int i=0;
for(i=0;x[i]!='\0';i++){
my_putchar_unlocked(x[i]);
}
}
int main(){
int OA9NF42T, i;
wmem = memarr;
//Timer t;
//t.set();
int n;
rd(n);
int m;
rd(m);
int l[n+m];
int r[n+m];
{
int Nzj9Y0kE;
for(Nzj9Y0kE=(0);Nzj9Y0kE<(n+m);Nzj9Y0kE++){
rd(l[Nzj9Y0kE]);
rd(r[Nzj9Y0kE]);
}
}
int k;
rd(k);
//wt_L(t.get());
//wt_L('\n');
sortA(n,l,r);
sortA(m,l+n,r+n);
//wt_L(t.get());
//wt_L('\n');
for(i=(0);i<(n+m-1);i++){
if(i!=n-1&&r[i]>=l[i+1]){
int bs24PFPc;
for(bs24PFPc=(0);bs24PFPc<(k);bs24PFPc++){
wt_L('1');
wt_L(' ');
}
exit(0);
}
}
//wt_L(t.get());
//wt_L('\n');
for(OA9NF42T=(0);OA9NF42T<(k);OA9NF42T++){
int p;
rd(p);
int j=n-1;
for(i=(n);i<(n+m);i++){
int lmouyaID;
int Dc_3QP3Y;
int myTeyldV;
lmouyaID = -1;
Dc_3QP3Y = j+1;
while(lmouyaID+1 < Dc_3QP3Y){
myTeyldV = lmouyaID + Dc_3QP3Y >>1;
if(l[myTeyldV]+l[i]>2*p){
Dc_3QP3Y = myTeyldV;
}
else{
lmouyaID = myTeyldV;
}
}
j=lmouyaID;
if(j>=0&&r[j]>=2*p-r[i]){
wt_L('1');
wt_L(' ');
goto next;
}
}
wt_L('0');
wt_L(' ');
next:
;
}
//wt_L(t.get());
//wt_L('\n');
return 0;
}
template<class T> inline void wt_L(vector<T> x){
int fg = 0;
for(auto a : x){
if(fg){
my_putchar_unlocked(' ');
}
fg = 1;
wt_L(a);
}
}
template<class T> inline void wt_L(set<T> x){
int fg = 0;
for(auto a : x){
if(fg){
my_putchar_unlocked(' ');
}
fg = 1;
wt_L(a);
}
}
template<class T> inline void wt_L(multiset<T> x){
int fg = 0;
for(auto a : x){
if(fg){
my_putchar_unlocked(' ');
}
fg = 1;
wt_L(a);
}
}
template<class T1, class T2> inline void wt_L(pair<T1,T2> x){
wt_L(x.first);
my_putchar_unlocked(' ');
wt_L(x.second);
}
tails