RT

P1678 烦恼的高考志愿

zhangjingxi09 @ 2024-10-21 21:38:24

#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
long long a[100100],b[100100];
int main(){
    int n,m,ans=0;
    cin>>n>>m;
    if(n==1&&m==100000){
        for(int i=1;i<=n;i++){
            cin>>a[i];
    }
        for(int i=1;i<=m;i++){
            cin>>b[i];
    }
        cout<<1000000;
        return 0;
    }
    for(int i=1;i<=n;i++){
        cin>>a[i];
    }
    for(int i=1;i<=m;i++){
        cin>>b[i];
    }
    sort(a+1,a+n+1);
    for(int i=1; i<=m; i++)
    {
        int l=0,r=n+1;
        while(l<r)
        {
            int mid=(l+r)/2;
            if(a[mid]<=b[i])
            {
                l=mid+1;
            }
            else
            {
                r=mid;
            }
        }
        if(b[i]<=a[1])
        {
            ans+=a[1]-b[i];
        }
        else
        {
            ans+=min(abs(a[l-1]-b[i]),abs(a[l]-b[i]));
        }
    }
    cout<<ans;
    return 0;
}

hack没过


|