Submission #432549

#TimeUsernameProblemLanguageResultExecution timeMemory
432549daniel920712Sorting (IOI15_sorting)C++14
8 / 100
4 ms332 KiB
#include "sorting.h"
#include <iostream>
using namespace std;
int findSwapPairs(int N, int S[], int M, int X[], int Y[], int P[], int Q[])
{
    int i,j,now=0,ok;
    for(i=N-1;i>=0;i--)
    {
        ok=1;
        for(j=0;j<N;j++) if(S[j]!=j) ok=0;
        if(ok) break;
        swap(S[X[now]],S[Y[now]]);
        for(j=0;j<N;j++)
        {
            if(S[j]==i)
            {
                if(i!=j)
                {
                    P[now]=i;
                    Q[now]=j;
                }
                else
                {
                    P[now]=1;
                    Q[now]=0;
                }
                swap(S[P[now]],S[Q[now]]);
                now++;
                break;
            }
        }

    }
    if(S[0]==1)
    {
        if(S[1]!=0) while(1);
        if(X[now]==0&&Y[now]==0)
        {
            P[now]=i;
            Q[now]=j;
            swap(S[P[now]],S[Q[now]]);
            now++;
        }
        else return 1/0;

    }
	return now;
}


Compilation message (stderr)

sorting.cpp: In function 'int findSwapPairs(int, int*, int, int*, int*, int*, int*)':
sorting.cpp:44:22: warning: division by zero [-Wdiv-by-zero]
   44 |         else return 1/0;
      |                     ~^~
sorting.cpp:4:39: warning: unused parameter 'M' [-Wunused-parameter]
    4 | int findSwapPairs(int N, int S[], int M, int X[], int Y[], int P[], int Q[])
      |                                   ~~~~^
sorting.cpp:41:35: warning: 'j' may be used uninitialized in this function [-Wmaybe-uninitialized]
   41 |             swap(S[P[now]],S[Q[now]]);
      |                              ~~~~~^
#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...