QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#661901 | #9345. Artful Paintings | wly_sh | WA | 12ms | 8204kb | C++23 | 2.3kb | 2024-10-20 18:54:33 | 2024-10-20 18:54:35 |
Judging History
answer
#include<bits/stdc++.h>
#define ll long long
#define db long double
#define mk make_pair
#define eb emplace_back
#define fo(i,a,b) for(ll (i)=(a);(i)<=(b);(i)++)
#define fd(i,a,b) for(ll (i)=(a);(i)>=(b);(i)--)
using namespace std;
const int N=1e5+10;
const int mo=1e9+7;
int n,m1,m2;
struct edge {
int v, w, next;
} e[N<<1];
int head[N], vis[N], tot[N], cnt;
long long ans, dist[N];
void R(int &x){
int t=0;
char ch;
for (ch=getchar();!('0'<=ch && ch<='9');ch=getchar());
for (;('0'<=ch && ch<='9');ch=getchar()) t=t*10+ch-'0';
x=t;
}
void addedge(int u, int v, int w) {
// cout<<u<<" "<<v<<" "<<w<<"\n";
e[++cnt].v = v;
e[cnt].w = w;
e[cnt].next = head[u];
head[u] = cnt;
}
int l[N],r[N],k[N];
queue<int> q;
bool check(int Sn){
cnt=0;
for (int i = 0; i <= n; i++) vis[i]=0,tot[i]=head[i]=0,dist[i]=1e9;
for (int i = 1; i <= m1; i++){
addedge(r[i], l[i]-1, -k[i]);
}
for (int i = m1+1; i <= m1+m2; i++){
addedge(l[i]-1, r[i], Sn-k[i]);
}
for (int i = 1; i <= n; i++) addedge(i-1, i, 1); //Si-1 - Si >= -1
for (int i = 1; i <= n; i++) addedge(i, i-1, 0); //Si-Si-1>=0
addedge(n, 0, -Sn);
addedge(0, n, Sn);
dist[0] = 0;
vis[0] = 1;
while (!q.empty()) q.pop();
q.push(0);
while (!q.empty()) {
int cur = q.front();
q.pop();
vis[cur] = 0;
for (int i = head[cur]; i; i = e[i].next)
if (dist[cur] + e[i].w < dist[e[i].v]) {
dist[e[i].v] = dist[cur] + e[i].w;
if(dist[e[i].v]<0) return false;
if (!vis[e[i].v]) {
vis[e[i].v] = 1;
q.push(e[i].v);
tot[e[i].v]++;
if (tot[e[i].v] >= n) {
return false;
}
}
}
}
return true;
}
void solve(){
R(n);R(m1);R(m2);
fo(i,1,m1){
R(l[i]);R(r[i]);R(k[i]);
}
fo(i,m1+1,m1+m2){
R(l[i]);R(r[i]);R(k[i]);
}
int L=0,R=n,m;
while(L<R){
m=(L+R)>>1;
if(check(m)) R=m;
else L=m+1;
}
printf("%d\n",L);
}
int main(){
int T;
R(T);
while(T--) solve();
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 5752kb
input:
1 3 1 1 1 2 1 2 2 1
output:
1
result:
ok single line: '1'
Test #2:
score: 0
Accepted
time: 2ms
memory: 8204kb
input:
1 1000 500 500 479 860 170 73 939 25 363 772 30 185 584 89 326 482 10 784 949 23 384 740 114 233 693 45 167 724 211 217 436 95 46 701 153 138 585 67 321 388 11 114 890 194 407 854 74 438 845 117 9 718 259 393 576 35 182 707 257 451 766 136 150 382 31 468 785 40 202 490 46 326 815 59 272 441 77 123 8...
output:
492
result:
ok single line: '492'
Test #3:
score: 0
Accepted
time: 7ms
memory: 7888kb
input:
1 3000 1000 1000 497 660 17 36 1021 195 2363 2786 90 1202 1218 5 1443 1627 76 2398 2642 59 1614 2082 296 2241 2286 3 360 2995 1736 2163 2566 245 526 990 103 916 1774 392 523 762 38 140 1912 187 472 2868 33 945 1039 60 739 2666 99 865 1440 143 1603 2378 97 672 1202 322 75 1406 367 1483 2534 397 1875 ...
output:
1977
result:
ok single line: '1977'
Test #4:
score: 0
Accepted
time: 12ms
memory: 7872kb
input:
1 3000 3000 3000 1277 1792 170 1578 1791 2 880 1814 109 2391 2691 185 385 1470 379 882 1802 315 1104 1616 310 121 1609 358 730 1880 729 1199 2068 535 666 2098 210 1642 1765 64 11 1567 437 188 2911 1398 2255 2257 0 2123 2428 32 797 1981 566 463 2583 125 517 2603 62 35 820 10 1446 2327 142 260 2997 92...
output:
1992
result:
ok single line: '1992'
Test #5:
score: 0
Accepted
time: 0ms
memory: 5836kb
input:
3 1000 500 500 591 664 15 735 959 57 537 897 80 744 964 57 666 917 58 121 545 83 352 374 2 300 377 20 140 889 156 658 905 59 395 595 36 675 784 22 593 967 86 435 620 34 478 846 75 46 680 124 81 882 165 20 471 87 279 393 27 693 716 4 125 734 121 154 921 160 109 691 114 3 802 160 743 833 19 216 236 5 ...
output:
204 469 627
result:
ok 3 lines
Test #6:
score: -100
Wrong Answer
time: 1ms
memory: 8104kb
input:
100 6 0 1 5 5 5 6 8 2 1 2 0 2 4 2 2 5 2 2 5 2 3 6 3 3 5 2 4 6 2 2 2 0 3 4 1 2 4 1 12 7 2 3 7 2 4 7 1 5 10 5 1 7 6 2 3 0 6 9 3 1 5 2 4 9 6 3 11 2 18 1 6 2 10 5 3 17 1 3 11 4 10 18 5 7 18 2 1 13 2 11 18 6 15 4 10 9 15 1 5 11 3 6 14 2 4 12 3 5 13 0 8 9 1 1 4 3 4 5 2 14 14 3 9 15 2 2 4 3 10 14 3 3 6 2 6...
output:
5 3 10 8 3 11 2 12 0 2 7 0 0 1 5 0 0 5 1 11 12 1 2 1 5 1 7 2 2 1 2 3 1 0 9 1 2 0 1 7 2 1 2 5 3 1 8 12 2 2 0 1 0 6 4 1 0 1 9 2 4 4 5 12 3 6 2 4 1 17 1 5 2 7 0 2 4 1 6 0 6 6 4 5 14 2 5 3 0 4 1 1 1 8 10 13 2 1 8 2
result:
wrong answer 46th lines differ - expected: '0', found: '1'