QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#327584 | #1856. Interval | Maverik | AC ✓ | 331ms | 77980kb | C++23 | 3.6kb | 2024-02-15 11:00:08 | 2024-02-15 11:00:09 |
Judging History
answer
#include <bits/stdc++.h>
#define int long long
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();}
while (ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();}
return x*f;
}
typedef pair<int,int> pii;
const int maxn=3e5+10,mod=998244353;
inline int qpow(int s,int t)
{
int res=1,base=s%mod;
while(t){ if(t&1) res=res*base%mod; base=base*base%mod,t>>=1; }
return res;
}
int n,Q,ans[maxn];
pii seg[maxn];
vector<pii>qbuc[maxn];
struct Matrix
{
int a,b,c;
Matrix(int A=0,int B=0,int C=0){ a=A,b=B,c=C; }
inline void clear(){ a=0,b=0,c=0; }
inline bool clean(){ return !a && !b && !c; }
};
struct Vector
{
int pos,sum,len;
Vector(int a=0,int b=0,int c=0){ pos=a,sum=b,len=c; }
};
inline Matrix operator * (const Matrix X,const Matrix Y)
{ return Matrix(X.a+Y.a,X.b+Y.b,X.c+Y.c+X.b*Y.a); }
inline Vector operator * (const Vector X,const Matrix Y)
{ return Vector(X.pos+Y.b*X.len,Y.a*X.pos+X.sum+Y.c*X.len,X.len); }
inline Vector operator + (const Vector X,const Vector Y)
{ return Vector(X.pos+Y.pos,X.sum+Y.sum,X.len+Y.len); }
#define ls (x<<1)
#define rs (x<<1|1)
#define mid ((l+r)>>1)
struct node{ Vector mx; Matrix tag; }t[maxn<<2];
inline void pushup(int x){ t[x].mx=t[ls].mx+t[rs].mx; }
inline void updata(int x,const Matrix &T){ t[x].mx=t[x].mx*T,t[x].tag=t[x].tag*T; }
inline void pushdown(int x)
{
if(!t[x].tag.clean())
updata(ls,t[x].tag),updata(rs,t[x].tag),t[x].tag.clear();
}
inline void build(int x,int l,int r)
{
t[x].mx=Vector(0,0,r-l+1);
if(l!=r) build(ls,l,mid),build(rs,mid+1,r);
}
inline void modify(int x,int l,int r,int L,int R,const Matrix &v)
{
if(L<=l && r<=R) return updata(x,v);
pushdown(x);
if(L<=mid) modify(ls,l,mid,L,R,v);
if(R>mid) modify(rs,mid+1,r,L,R,v);
pushup(x);
}
inline int qsum(int x,int l,int r,int L,int R)
{
if(L<=l&&r<=R) return t[x].mx.sum;
pushdown(x);
if(R<=mid) return qsum(ls,l,mid,L,R);
if(L>mid) return qsum(rs,mid+1,r,L,R);
return qsum(ls,l,mid,L,R)+qsum(rs,mid+1,r,L,R);
}
inline void Add(int l,int r,int x){ modify(1,1,n,l,r,Matrix(0,x,0)); }
inline void Copy(){ modify(1,1,n,1,n,Matrix(1,0,0)); }
#undef mid
struct onode{
int l,r,v;
onode(){} onode(int ll,int rr,int vv){ l=ll,r=rr,v=vv; }
friend bool operator <(const onode&A,const onode&B){ return A.l!=B.l?A.l<B.l:A.r<B.r; }
};
typedef set<onode>::iterator iter;
set<onode>s;
inline iter split(int p)
{
iter it=s.lower_bound(onode(p,0,0));
if(it!=s.end() && it->l==p) return it;
auto [l,r,v]=*(--it); s.erase(it);
s.insert(onode(l,p-1,v));
return s.insert(onode(p,r,v)).first;
}
inline void omodify(int l,int r,int cur)
{
iter R=split(r+1),L=split(l);
for(iter it=L;it!=R;it++) Add(it->v+1,cur,it->r-it->l+1);
s.erase(L,R),s.insert(onode(l,r,cur));
}
inline void solve()
{
n=read(),Q=read();
int maxr=0,Pos=0;
for(int i=1,l,r;i<=n;i++)
{
l=read(),r=read();
if(l<r) seg[++Pos]=pii(l+1,r);
}
n=Pos;
for(int i=1;i<=n;i++) maxr=max(maxr,seg[i].second);
build(1,1,n);
s.insert(onode(0,maxr,0));
for(int i=1,l,r;i<=Q;i++) l=read(),r=read(),qbuc[r].emplace_back(l,i);
for(int i=1;i<=n;i++)
{
auto [l,r]=seg[i];
omodify(l,r,i),Copy();
for(auto [l,id]:qbuc[i])
{
int len=i-l+1,Inv=qpow(len*(len-1)/2+len,mod-2);
ans[id]=qsum(1,1,n,l,i)%mod*Inv%mod;
}
}
for(int i=1;i<=Q;i++) cout<<ans[i]<<'\n';
}
signed main(){ solve(); }
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 4ms
memory: 64584kb
input:
2 1 1 5 4 8 1 2
output:
5
result:
ok single line: '5'
Test #2:
score: 0
Accepted
time: 322ms
memory: 77084kb
input:
200000 200000 4455910 81388645 47311584 83266871 2302533 83282606 37122147 63131823 54323252 71482325 24756264 89591670 24683722 45216831 3664402 90722731 20344438 58063424 18767188 61197540 44999082 54242932 20654464 60691742 7958498 88508082 24272079 25874809 63258707 70661986 48698861 63769448 40...
output:
149335631 625872899 209671594 397057221 578135657 297831629 94774378 307772432 239408309 471895751 669425606 877865414 844752350 718252313 836967965 783715970 104202952 267797959 230943760 353441337 534943711 898629127 202447492 482139796 584565257 643363500 741398873 973335212 218908116 460246124 7...
result:
ok 200000 lines
Test #3:
score: 0
Accepted
time: 314ms
memory: 77976kb
input:
200000 200000 59472069 72972050 67908358 77047425 72985575 81651787 6315811 61861426 41660138 92416481 51151414 99016704 49510155 88049625 52884542 81112319 19816189 96600746 58031429 74819750 29166518 42319726 37496143 75799252 30272355 58818291 9729644 33936326 50525873 89343595 31288675 72984939 ...
output:
112873395 229817 988723202 209421734 745689826 947849797 685595348 857351159 181551093 725880374 947697873 720715142 994518160 151380496 199199272 43615950 218276212 760766804 280524477 682383588 191232801 842292816 816219832 594681440 142319050 96178971 65822454 41925046 760523490 43249520 97205229...
result:
ok 200000 lines
Test #4:
score: 0
Accepted
time: 320ms
memory: 77900kb
input:
200000 200000 37555493 51553599 21084875 98570539 15776848 17464352 41890305 49499799 18383340 23964320 12711157 78309847 24079692 25849716 3784429 74854865 74063747 79848469 48250473 57104182 54347000 89383475 45682569 59370526 52586212 88937011 35378697 47030547 42825744 67833715 38999389 42495210...
output:
565033852 332437760 156535590 138787030 565880941 286297488 546191115 446725790 256121294 221277536 760535169 34574065 187812436 451881429 130034003 462576461 492194139 377205957 442879990 534004726 300187126 189615467 416675976 408385577 708755163 474147579 721036491 982388787 852172823 180621588 2...
result:
ok 200000 lines
Test #5:
score: 0
Accepted
time: 324ms
memory: 77168kb
input:
200000 200000 20069739 20671621 19898132 69424209 56910425 95126102 71662289 92683787 1235799 39317496 52570287 69238197 48906126 63649806 42049381 86265050 63096191 78568201 16648491 96368422 36447223 74494778 60790078 81244910 64279923 79932773 5348961 15803558 35125614 96580731 11551319 66781288 ...
output:
724483386 910778667 377502738 994436646 282430821 402168134 422964586 138416407 556222774 437130406 600372704 306343249 873386285 528321227 868835380 160898919 164236479 578321514 801905009 636165147 943369357 702806298 746991879 712823617 275148907 689327977 827518592 551184819 681947607 10065067 7...
result:
ok 200000 lines
Test #6:
score: 0
Accepted
time: 331ms
memory: 77968kb
input:
200000 200000 93618583 98755045 86390 13678686 24218459 46613393 40900479 46658464 60251651 88572685 26830726 85573749 6482600 28508367 63712967 64019704 32815759 91568106 40665367 85046509 28735164 94642555 43310781 75897588 2246630 34590131 13410478 96228418 27425484 70038148 31258855 79070545 319...
output:
119292102 76646473 231491193 370840742 573509871 826867498 944525207 901749239 295385734 611922675 911777486 621230888 955469824 189475929 545409242 207879002 568490237 129722490 726161240 13582391 481392157 156560919 713793467 556195632 268276421 17879964 411257428 808789178 248519797 848074039 633...
result:
ok 200000 lines
Test #7:
score: 0
Accepted
time: 317ms
memory: 76512kb
input:
200000 200000 21943236 76838469 25715868 52683432 3567713 86059466 76430447 79051763 70876867 86218511 6123870 47133492 53334800 99058498 41160884 85990027 37320214 74815828 34705416 63509935 64533437 75798912 65185164 96037801 24560487 59676148 21877471 26504699 14692651 93752460 60577637 91813963 ...
output:
248021684 805053852 723969855 522455751 750894085 2216616 689586368 387641653 906107416 42489193 5511026 474744178 206514842 263657114 78009513 452091392 197725511 4429041 664765225 121173208 907816208 510532332 933758056 838237676 578822584 144241833 21453022 474961381 980707568 409058152 996334953...
result:
ok 200000 lines
Test #8:
score: 0
Accepted
time: 327ms
memory: 76536kb
input:
200000 200000 54921893 90459376 51345346 51496689 35570947 82916966 11235134 22235751 7152666 48148346 8693236 30127414 27904337 36858589 18608801 48151838 13353151 96600476 31907953 73969657 27895365 89713919 60888414 82026843 35019060 56939752 2302332 39598920 6992521 72242580 30087907 59333189 26...
output:
560021271 779167220 815231492 614759989 162589250 880437100 802283478 767706251 918272040 97844949 951229529 786897750 737134131 510229873 819289986 185381858 425466253 540706260 961670448 629919942 149232855 67226103 211020871 455055945 271367185 171008168 991351226 53522333 352402529 516121044 594...
result:
ok 200000 lines
Test #9:
score: 0
Accepted
time: 324ms
memory: 77980kb
input:
200000 200000 38038021 69040924 82007527 90501435 17042028 25273916 65419739 81198606 33119526 35485232 9420557 65220276 52730771 79691383 41280910 75154865 96072226 96600873 5338675 18266601 9861697 20183305 3901227 75995924 5329268 79253609 52693141 82727193 54068199 95956893 21819711 49341282 296...
output:
7030934 211041663 62370377 419232187 968990002 518090358 946771397 680313490 732345783 860455476 610198712 853631753 516101826 3591542 728323784 659967673 309742379 270158625 909742643 310791126 750997678 572990101 564197767 28300028 291536791 986560404 161280350 946411378 332373318 746633013 813588...
result:
ok 200000 lines
Test #10:
score: 0
Accepted
time: 328ms
memory: 77912kb
input:
200000 200000 16121445 37557065 52861197 84281989 1423986 64719989 8603727 16003293 17789414 59086385 26780019 83680997 12458769 27300308 18728827 37316676 25072788 50319784 12306650 73736693 67247054 84785282 20742906 91103433 1567466 30415285 8376246 65787362 41335365 74447013 18851552 34563130 50...
output:
423771160 663645747 571915318 51293397 62092310 215460585 744070931 502809680 456997262 898200681 615306696 326299988 224129805 668084399 373001179 567479729 291163299 255288316 509561256 288660870 993268688 204832939 4459354 422983825 246541618 864905781 692401710 454728073 954835506 598048950 4726...
result:
ok 200000 lines