Cod sursa(job #3166913)

Utilizator nicushor21Pirlog Marian Nicolae nicushor21 Data 9 noiembrie 2023 19:05:00
Problema Pachete Scor 10
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.35 kb
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
int n,cnt,i,j,k,aux,x,st,dr,mid,nrdr,CXpos,CYpos,pos,adv;
pair <int,int> clnt[50001],minim[50001];
int main(){
    ifstream fin("pachete.in");
    ofstream fout("pachete.out");
    fin>>n;
    fin>>clnt[50000].first>>clnt[50000].second;
    for(i=0;i<n;i++){
        fin>>clnt[i].first>>clnt[i].second;
        minim[i].first=abs(clnt[i].first-clnt[50000].first)+abs(clnt[i].second-clnt[50000].second);
        minim[i].second=i;
    }
    sort(minim,minim+n);
    adv=1;
    while(adv==1){
        CXpos=clnt[50000].first; CYpos=clnt[50000].second; pos=50000;
        adv=0;
        for(i=0;i<n;i++){
            if(clnt[minim[i].second].first!=-1){
                adv=1;
                if(minim[i].first==(abs(CXpos-clnt[minim[i].second].first)+abs(CYpos-clnt[minim[i].second].second)+minim[pos].first)){
                    CXpos=clnt[minim[i].second].first;
                    CYpos=clnt[minim[i].second].second;
                    clnt[minim[i].second].first=-1;
                    pos=i;
                    //cout<<CXpos<<" "<<CYpos<<" "<<i<<'\n';
                    //break;
                }
            }
        }
        if(pos!=50000)  nrdr++;
        //cout<<1<<'\n';
    }
    fout<<nrdr;
    fin.close();
    fout.close();
    return 0;
}