QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#627262 | #9345. Artful Paintings | guodong# | TL | 242ms | 3960kb | C++14 | 2.2kb | 2024-10-10 15:23:24 | 2024-10-10 15:23:25 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define For(i,a,b) for(int i = a; i <= b; ++i)
#define pb push_back
#define mp make_pair
class spfa{
private:
int n;
vector<vector<pair<int,int>>> To;
vector<int> dis,cnt,vis;
queue<int> q;
public:
spfa(int siz = 0){
n = siz;
To.resize(n + 1);
dis.resize(n + 1,0);
cnt.resize(n + 1,0);
vis.resize(n + 1,0);
}
void Add(int u,int v,int w){
To[u].pb(mp(v,w));
}
const int inf = 1e9;
int Spfa(){
For(i,0,n){
q.push(i);
vis[i] = 1;
cnt[i]++;
}
while(!q.empty()){
int u = q.front();
if(cnt[u] > 2 * n)
return 1;
q.pop();
vis[u] = 0;
for(auto &arr : To[u]){
if(dis[arr.first] > dis[u] + arr.second ){
dis[arr.first] = dis[u] + arr.second;
if(!vis[arr.first]){
cnt[arr.first]++;
vis[arr.first] = 1;
q.push(arr.first);
}
}
}
}
return 0;
}
};
vector<pair<pair<int,int>,int>> Rule1;
vector<pair<pair<int,int>,int>> Rule2;
bool Judge(int n,int v){
spfa M = spfa(n + 1);
M.Add(0,n,v);
// sum[n] - sum[0] <= v;
M.Add(n,0,-v);
// sum[n] - sum[0] >= v;
For(i,1,n){
M.Add(i-1,i,1);
M.Add(i,i-1,0);
}
for(auto &tmp : Rule1){
int l = tmp.first.first;
int r = tmp.first.second;
int k = tmp.second;
// greater
M.Add(r,l-1,-k);
}
for(auto &tmp : Rule2){
int l = tmp.first.first;
int r = tmp.first.second;
int k = tmp.second;
// smaller
M.Add(l - 1,r,v - k);
}
if(M.Spfa())
return 0;
return 1;
}
signed main(){
#ifdef NICEGUODONG
freopen("data.in","r",stdin);
#endif
ios::sync_with_stdio(false);
int T;
cin >> T;
while(T--){
int n,m1,m2;
Rule1.clear(),Rule2.clear();
cin >> n >> m1 >> m2;
For(i,1,m1){
int l,r,k;
cin >> l >> r >> k;
auto tmp = mp(mp(l,r),k);
Rule1.pb(tmp);
}
For(i,1,m2){
int l,r,k;
cin >> l >> r >> k;
auto tmp = mp(mp(l,r),k);
Rule2.pb(tmp);
}
int l = 0,r = n,ans = 0;
while(l <= r){
int mid = (l + r) >> 1;
if(Judge(n,mid)){
r = mid - 1;
ans = mid;
}
else{
l = mid + 1;
}
}
cout << ans << '\n';
}
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3556kb
input:
1 3 1 1 1 2 1 2 2 1
output:
1
result:
ok single line: '1'
Test #2:
score: 0
Accepted
time: 242ms
memory: 3960kb
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: -100
Time Limit Exceeded
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 ...