QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#622531#2541. Coins and Boxesucup-team3474#WA 34ms11172kbC++201.4kb2024-10-08 22:21:322024-10-08 22:21:32

Judging History

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

  • [2024-10-08 22:21:32]
  • 评测
  • 测评结果:WA
  • 用时:34ms
  • 内存:11172kb
  • [2024-10-08 22:21:32]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
const int N=214514;
typedef long long ll;
typedef pair<ll,ll> PII;
ll n,a[N],b[N];

map<ll,ll> mp;

vector<int> pos;

int main(){
    cin>>n;
    for(int i=1;i<=n;i++){
        scanf("%lld",&a[i]);
    }    
    for(int i=1;i<=n;i++){
        scanf("%lld",&b[i]);
    }
    vector<PII> v;
    
    for(int i=1;i<=n;i++) v.push_back({a[i],-1});
    for(int i=1;i<=n;i++) v.push_back({b[i],1});
    sort(v.begin(),v.end());
    ll now=0,val=0;
    int i=0,j=0;
    ll ans=0;
    while(i<v.size()){
        // cout<<i<<" "<<j<<" "<<val<<endl;
        now+=v[i].second;
        i++;
        while(now!=0){
            now+=v[i].second;
            i++;
        }

        if(v[j].second==1){
            ans+=v[i-1].first-val;
            val=v[i-1].first;
        }else{
            ll ad=v[i-1].first-val+v[i-1].first-v[j].first;
            // cout<<ad<<endl;
            if(i!=v.size()) ad+=v[i-1].first-v[j].first;
            // cout<<ad<<endl;
            ans+=ad;
            val=v[i-1].first;
        }
        pos.push_back(i);
        if(i!=v.size())
        mp[i]=ans;
        // cout<<ans<<endl;
        j=i;
    }
    for(int i=0;i<2*n;i++){
        if(!mp.count(i)) continue;
        // cout<<i<<endl;
        ll res=mp[i]+v.back().first*2-v[i-1].first-v[i].first;
        ans=min(ans,res);
    }
    cout<<ans<<endl;
}

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 5644kb

input:

4
1 6 7 12
3 5 10 11

output:

21

result:

ok answer is '21'

Test #2:

score: 0
Accepted
time: 0ms
memory: 3672kb

input:

2
1 2
1 1000000000

output:

1999999998

result:

ok answer is '1999999998'

Test #3:

score: 0
Accepted
time: 34ms
memory: 10928kb

input:

100000
967 3246 9492 10300 15195 16650 26911 54855 83695 112841 125511 137160 153051 155859 177924 187843 214838 219388 247276 249612 250188 253873 257830 261805 281312 297030 298332 325904 333218 339683 374111 387794 396645 403705 426710 436137 463368 481801 501933 509267 511332 515225 515629 51686...

output:

1722240547

result:

ok answer is '1722240547'

Test #4:

score: 0
Accepted
time: 31ms
memory: 11172kb

input:

99999
21462 34020 34146 53248 90164 92224 98994 104980 115343 128362 134989 136436 149380 154685 181264 182990 205001 209721 213620 233438 238959 247963 248072 250838 259705 264873 265121 298034 298867 304937 325609 325758 334451 341321 363426 374659 396164 414311 424279 445253 454970 482336 505116 ...

output:

1469284712

result:

ok answer is '1469284712'

Test #5:

score: 0
Accepted
time: 30ms
memory: 10664kb

input:

99998
662 69065 90516 119024 146215 146391 152295 166603 168318 170511 185082 191597 203549 220156 222019 233462 233502 235131 247440 254351 278648 283202 287150 312840 318686 332272 344963 374235 386478 390405 391828 421104 424282 437621 438490 444582 448853 455370 468914 482565 507931 528031 53129...

output:

1782189953

result:

ok answer is '1782189953'

Test #6:

score: -100
Wrong Answer
time: 30ms
memory: 9928kb

input:

99997
1036 12224 16393 26262 26675 29724 38487 44675 52169 56398 62749 104395 122412 123854 140544 184458 187993 191357 204244 216509 225345 225651 229547 231850 240978 243269 250984 255594 271277 281251 286151 300018 301497 302196 302973 310350 321582 323564 328049 332303 335816 352755 356321 35992...

output:

2000086581

result:

wrong answer expected '1999997448', found '2000086581'