Submission #895798

#TimeUsernameProblemLanguageResultExecution timeMemory
895798ozner77Arranging Shoes (IOI19_shoes)C++17
10 / 100
1 ms500 KiB
#include "shoes.h"
#include <bits/stdc++.h>
#include <vector>
#include <iostream>
#include <string>
using namespace std;
long long count_swaps(std::vector<int> s) {
	int a,b,c,d,e=s.size(),xd=-1;
	bool fua=true;
	long long swaps=0;
	a=s[0];
	b=s[0];
	for(int k=0;k<e;k+=2){
        a=s[k];
        b=s[k];
	for(int i=k;i<e;i++){
        if(s[i]<0){
            while(true){
                xd++;
                if(s[i+xd]+s[i]==0){
                    fua=false;
                    break;
                }else if(i-xd==k){
                    break;
                }else if(s[i-xd]+s[i]==0 && i-xd>=k+1){
                    swaps++;
                    fua=false;
                    break;
            }
            }
        if(fua){
            swaps++;
            if(s[i]==s[k]){
                swaps--;
            }
            s[k]=s[i];
            s[i]=a;
            c=s[k+1];
            d=s[k+1];
            for(int j=k+1;j<e;j++){
                if(s[j]+s[k]==0){
                        swaps++;
                    if(s[j]==s[k+1]){
                        swaps--;
                    }
                    s[k+1]=s[j];
                    s[j]=c;
                    break;
                }else if(i>=k+2){
                    swaps++;
                    d=s[j];
                    s[j]=c;
                    c=d;
                }
            }
        break;
        }
        }else if(i>=k+1){
            swaps++;
            b=s[i];
            s[i]=a;
            a=b;
        }
}
	}
	return swaps;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...