QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#164617#7118. Closing TimeunputdownableCompile Error//C++172.8kb2023-09-05 11:12:212024-04-28 07:28:06

Judging History

你现在查看的是最新测评结果

  • [2024-04-28 07:28:06]
  • 管理员手动重测本题所有提交记录
  • [2023-09-05 11:12:22]
  • 评测
  • [2023-09-05 11:12:21]
  • 提交

answer

// #pragma GCC optimize("Ofast")
// #pragma GCC optimize("unroll-loops")
// #pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,avx2")
#include "closing.h"
#include <bits/stdc++.h>
// #define int long long
#define i64 long long
#define pii pair <i64, i64> 
using namespace std;
vector <pii> E[200005];
i64 depx[200005],depy[200005];
i64 sig[400005],cnt1,cnt2;
pii val[200005];
i64 vvv[400005];
inline void dfs(int x,int f,i64*dep) {
    for(pii e : E[x]) {
        if(e.first==f) continue;
        dep[e.first]=dep[x]+e.second;
        dfs(e.first,x,dep);
    }
} 
inline void check(int&R,i64&sum,i64 lim) { if(lim<0) return R=-1000000,void(); while(sum>lim) sum-=sig[R--]; }
int max_score(int n, int x, int y,i64 k, std::vector<int> U, std::vector<int> V, std::vector<int> W) {
    for(int i=0; i<n; ++i) E[i].clear(); cnt1=cnt2=0; int k0=k;
    int m=U.size();
    for(int i=0; i<m; ++i) E[U[i]].emplace_back(V[i],W[i]);
    for(int i=0; i<m; ++i) E[V[i]].emplace_back(U[i],W[i]);
    dfs(x,-1,depx);
    dfs(y,-1,depy);
    // for(int i=0; i<n; ++i) cerr<<depx[i]<<' '; cerr<<endl;
    // for(int i=0; i<n; ++i) cerr<<depy[i]<<' '; cerr<<endl;
    int cnt=0;
    for(int i=0,a,b; i<n; ++i) {
        vvv[i+1]=depx[i];
        vvv[i+n+1]=depy[i];
        if(depx[i]+depy[i]==depx[y]) {
            k-=min(depx[i],depy[i]);
            sig[++cnt1]=max(depx[i],depy[i])-min(depx[i],depy[i]);
            ++cnt;
            continue;
        }
        if(depx[i]>depy[i]) a=depy[i],b=depx[i]-a; 
        else                a=depx[i],b=depy[i]-a;
        if(a<b) sig[++cnt1]=a,sig[++cnt1]=b;
        else    val[++cnt2]=(pii){a+b,a};
    }
    sort(val+1,val+cnt2+1);
    sort(sig+1,sig+cnt1+1);
    sort(vvv+1,vvv+2*n+1); vvv[2*n+1]=k0+1;
    int p=0; i64 s1=0; 
    while(s1+vvv[p+1]<=k0) s1+=vvv[++p];
    int Ans=p;
    // cerr<<Ans<<"----------"<<endl;
    // for(int i=1; i<=cnt1; ++i) cerr<<sig[i]<<' '; cerr<<endl;
    // for(int i=1; i<=cnt2; ++i) cerr<<val[i].first<<' '<<val[i].second<<'|'; cerr<<endl;
    int R=0; i64 sum=0; sig[cnt1+1]=k+1;
    while(sum+sig[R+1]<=k) sum+=sig[++R];
    // cerr<<R<<' '<<sum<<endl;
    if(k>=0) Ans=max(Ans,R+cnt);
    // cerr<<"------------------"<<endl;
    if(k>=0) for(int i=1; i<=cnt2; ++i) {
        check(R,sum,k-val[i].second),Ans=max(Ans,2*i+R+cnt-1);
        check(R,sum,k-=val[i].first),Ans=max(Ans,2*i+R+cnt);
    } 
    return Ans;
}
vector <int> A,B,C;
signed main() {
    freopen("localinput","r",stdin);
    freopen("localoutput","w",stdout);
    i64 n,x,y,k;
    cin>>n>>x>>y>>k;
    for(int i=1,a,b,c; i<n; ++i) {
        cin>>a>>b>>c;
        A.push_back(a);
        B.push_back(b);
        C.push_back(c);
    } 
    cout<<max_score(n,x,y,k,A,B,C)<<endl;;
    return 0;
}

Details

answer.code: In function ‘int main()’:
answer.code:69:12: warning: ignoring return value of ‘FILE* freopen(const char*, const char*, FILE*)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   69 |     freopen("localinput","r",stdin);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
answer.code:70:12: warning: ignoring return value of ‘FILE* freopen(const char*, const char*, FILE*)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   70 |     freopen("localoutput","w",stdout);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/bin/ld: /tmp/cci7Q6bO.o: in function `main':
answer.code:(.text.startup+0x0): multiple definition of `main'; /tmp/ccEacUaO.o:implementer.cpp:(.text.startup+0x0): first defined here
collect2: error: ld returned 1 exit status