QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#198306 | #4246. Cactus is Money | hotboy2703 | ML | 1ms | 7000kb | C++14 | 4.0kb | 2023-10-03 12:38:16 | 2023-10-03 12:38:16 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
using ll = long long;
struct pt{
ll x,y;
pt operator + (pt p) const{
return {x+p.x, y+p.y};
}
pt operator - (pt p) const{
return {x-p.x, y-p.y};
}
ll operator * (pt p)const{
return x * p.y - y * p.x;
}
};
ll sq(pt a,pt b){
return (a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y);
}
void reorder_polygon(vector <pt> &p){
ll pos = 0;
for (ll i = 0;i < p.size();i ++){
if (p[i].y < p[pos].y || (p[i].y == p[pos].y && p[i].x < p[pos].x)){
pos = i;
}
}
rotate(p.begin(),p.begin() + pos,p.end());
}
ll orientation(pt a, pt b, pt c){
ll ori = (b-a)*(c-b);
if (ori == 0)return 0;
if (ori > 0)return 1;
if (ori < 0)return -1;
}
vector <pt> sum(vector <pt> P,vector <pt> Q){
//no mulipleple point counter clockwise
reorder_polygon(P);
reorder_polygon(Q);
P.push_back(P[0]);
P.push_back(P[1]);
Q.push_back(Q[0]);
Q.push_back(Q[1]);
vector <pt> result;
for (ll i = 1;i + 1 < P.size(); i++){
assert(orientation(P[i-1],P[i],P[i+1]) == 1);
}
ll i,j;
i = j = 0;
while (i < P.size() - 2 || j < Q.size() - 2){
result.push_back(P[i] + Q[j]);
auto cross = (P[i+1] - P[i]) * (Q[j+1] - Q[j]);
if (cross >= 0 && i < P.size() - 2){
++i;
}
if (cross <= 0 && j < Q.size() - 2){
++j;
}
}
return result;
}
void convex_hull(vector <pt> &P){
pt p0 = *min_element(P.begin(),P.end(),[=](pt a, pt b){return make_pair(a.y,a.x) < make_pair(b.y,b.x);});
sort(P.begin(),P.end(),[&p0](const pt &a,const pt &b){
auto o = orientation(p0,a,b);
if (o == 0){
return sq(p0,a) < sq(p0,b);
}
return (o == 1);
});
vector <pt> st;
for (ll i = 0;i < P.size();i ++){
while (st.size() > 1 && orientation(st[st.size() - 2],st[st.size() - 1],P[i]) == -1){
st.pop_back();
}
st.push_back(P[i]);
}
P = st;
}
const ll MAXN = 5e4;
ll n,m;
vector <ll> g[MAXN + 100];
ll pa[MAXN + 100];
bool in[MAXN + 100];
struct edge{
ll u,v,a,b;
};
ll depth[MAXN + 100];
edge all[MAXN * 5 + 100];
ll nxt(ll u, edge x){
return (x.u == u?x.v:x.u);
}
vector <pt> sex_min;vector <pt> tmp;
vector <vector <pt> > sex;
void dfs(ll u){
//cout<<u<<'\n';
for (auto id:g[u]){
auto v = nxt(u,all[id]);
if (!in[v]){
pa[v] = id;
in[v] = 1;
depth[v] = depth[u] + 1;
//cout<<id<<' '<<u<<' '<<v<<'\n';
dfs(v);
}
if (in[v]){
if (depth[v] > depth[u] + 1){
ll cur = v;
tmp.clear();
tmp.push_back({all[id].a,all[id].b});
while (cur != u){
tmp.push_back({all[pa[cur]].a,all[pa[cur]].b});
cur = nxt(cur,all[pa[cur]]);
}
convex_hull(tmp);
sex.push_back(tmp);
}
}
}
}ll sum_a,sum_b;
vector <pt> minkowski(ll l,ll r){
if (l == r){return sex[l];}
ll mid = (l + r) >> 1;
auto ll = minkowski(l,mid);
auto rr = minkowski(mid+1,r);
auto res = sum(ll,rr);
ll.clear();ll.shrink_to_fit();
rr.clear();rr.shrink_to_fit();
return res;
}
int main(){
ios_base::sync_with_stdio(0);cin.tie(nullptr);cout.tie(nullptr);
cin>>n>>m;
sum_a = sum_b = 0;
for (ll i = 1;i <= m;i ++){
cin>>all[i].u>>all[i].v>>all[i].a>>all[i].b;
g[all[i].u].push_back(i);
g[all[i].v].push_back(i);
sum_a += all[i].a;
sum_b += all[i].b;
}
in[1] = 1;
dfs(1);
ll ans = sum_a * sum_b;
sex_min = minkowski(0,sex.size() - 1);
for (auto x:sex_min){
ans = min(ans,(sum_a - x.x) * (sum_b - x.y));
}
cout<<ans<<'\n';
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 5912kb
input:
3 3 1 2 0 1000 2 3 0 1000 3 1 1 1
output:
0
result:
ok 1 number(s): "0"
Test #2:
score: 0
Accepted
time: 1ms
memory: 6768kb
input:
5 5 1 2 666 10 2 3 555 1000 3 1 444 345 1 4 222 234 2 5 333 123
output:
1185480
result:
ok 1 number(s): "1185480"
Test #3:
score: 0
Accepted
time: 1ms
memory: 6224kb
input:
5 6 1 3 12316 13729 1 2 171 10309 5 1 47389 7369 2 4 43318 36867 1 4 30728 43835 5 3 24437 31639
output:
6732185824
result:
ok 1 number(s): "6732185824"
Test #4:
score: 0
Accepted
time: 1ms
memory: 6984kb
input:
6 6 5 2 36032 49949 4 5 8963 9741 3 4 4004 35098 4 1 14459 30350 4 6 39612 8568 1 5 8645 16098
output:
11617618224
result:
ok 1 number(s): "11617618224"
Test #5:
score: 0
Accepted
time: 1ms
memory: 6836kb
input:
6 6 6 1 1516 16290 3 5 47834 15228 5 1 14795 44496 2 6 21296 36977 6 3 42659 16631 4 3 9808 31313
output:
13124412318
result:
ok 1 number(s): "13124412318"
Test #6:
score: 0
Accepted
time: 0ms
memory: 7000kb
input:
7 7 1 7 42781 13704 7 3 48779 17985 6 4 27969 24986 4 7 33333 35700 5 7 4859 49960 6 2 23927 33500 6 1 11232 15327
output:
24803495714
result:
ok 1 number(s): "24803495714"
Test #7:
score: 0
Accepted
time: 0ms
memory: 6360kb
input:
10 11 7 3 43798 8096 5 7 36600 4126 2 6 20599 15893 9 6 7541 5621 4 9 22047 10608 5 10 21235 2700 1 10 19260 8862 4 3 22407 37504 5 1 12867 1738 1 8 48480 15236 2 5 43525 13679
output:
19944198324
result:
ok 1 number(s): "19944198324"
Test #8:
score: 0
Accepted
time: 1ms
memory: 5024kb
input:
10 12 10 2 21765 14299 4 2 8316 29600 3 2 36018 33286 4 5 30741 46828 9 7 13354 18461 9 5 11896 14216 6 1 35705 34008 1 9 41496 21860 7 5 37709 34178 8 7 1595 27497 6 9 12139 37471 3 5 43310 12734
output:
39767313936
result:
ok 1 number(s): "39767313936"
Test #9:
score: 0
Accepted
time: 0ms
memory: 6328kb
input:
10 13 10 1 28967 29646 9 1 45852 47509 6 1 2590 36591 5 4 21715 40134 1 5 44167 42132 2 10 27289 12132 5 7 26720 1258 1 3 2762 28223 3 6 6966 48096 5 8 23536 33618 7 8 28326 9456 1 2 4885 15100 5 9 41414 32957
output:
43567826244
result:
ok 1 number(s): "43567826244"
Test #10:
score: 0
Accepted
time: 1ms
memory: 5732kb
input:
20 28 18 19 35583 99 15 18 30705 19256 14 18 20288 26882 18 4 39622 18793 11 7 47613 25425 8 18 33445 7046 18 13 37838 47190 18 1 47524 18152 8 10 20627 40858 18 6 49396 47654 9 18 9453 36001 20 18 33280 38985 11 18 47686 42244 1 20 8726 35210 14 6 20998 13452 18 10 10397 48525 19 4 45811 48722 5 17...
output:
196145757738
result:
ok 1 number(s): "196145757738"
Test #11:
score: 0
Accepted
time: 1ms
memory: 4732kb
input:
20 28 1 11 29270 12003 11 14 39731 27230 4 11 43657 44868 13 10 37887 17666 8 6 12758 4662 12 18 34016 15740 12 11 1123 44690 1 14 1866 31755 17 7 12441 26285 3 10 29159 11042 4 19 22612 12647 2 3 43899 27826 17 3 26727 7304 20 5 32807 49683 16 3 40800 14397 3 5 21244 13387 11 3 39919 35610 15 9 944...
output:
135255186000
result:
ok 1 number(s): "135255186000"
Test #12:
score: 0
Accepted
time: 1ms
memory: 6980kb
input:
500 627 218 441 9330 38888 394 403 39336 6683 81 319 10978 28288 157 204 27638 7127 58 38 7029 7446 168 100 23915 46064 180 151 42120 1549 18 238 15877 34786 37 259 37301 2159 463 185 4155 13849 77 355 5111 14848 62 486 19786 48858 132 408 41592 45835 245 378 46373 21496 291 20 36847 18682 435 213 3...
output:
115468900928208
result:
ok 1 number(s): "115468900928208"
Test #13:
score: 0
Accepted
time: 1ms
memory: 4892kb
input:
500 655 118 73 5102 36606 387 191 18264 17089 462 226 6016 40383 215 303 3543 6165 95 192 19518 19250 37 430 21505 26348 406 484 45283 8029 446 64 32626 30683 432 146 22720 12184 1 145 4822 43486 169 355 44960 12596 399 372 1339 28076 452 387 11774 33758 186 72 47444 20235 145 61 30207 39522 87 419 ...
output:
126690228324902
result:
ok 1 number(s): "126690228324902"
Test #14:
score: -100
Memory Limit Exceeded
input:
500 499 11 127 37123 28858 439 253 39067 7779 148 142 5215 35775 441 354 15081 38415 145 463 8601 8508 400 332 23071 25635 193 124 33687 31694 154 449 45482 46872 499 469 49487 28780 24 246 48364 48917 458 397 3906 33392 130 108 13072 11058 235 406 11881 17681 20 172 35252 25687 81 24 41900 11751 49...