Submission #1108069

#TimeUsernameProblemLanguageResultExecution timeMemory
1108069AvianshSorting (IOI15_sorting)C++17
0 / 100
83 ms77688 KiB
#include "sorting.h" #include <bits/stdc++.h> using namespace std; int findSwapPairs(int n, int s[], int m, int x[], int y[], int p[], int q[]) { int be[n]; int tp[n]; copy(s,s+n,tp); iota(be,be+n,0); int ber[m][n]; for(int i = m-1;i>=0;i--){ swap(be[x[i]],be[y[i]]); for(int j = 0;j<n;j++){ ber[i][be[j]]=j; } } int r = 0; for(int i = 0;i<n;i++){ swap(s[x[i]],s[y[i]]); int ind = find(s,s+n,i)-s; swap(s[ind],s[ber[r+1][i]]); p[r]=ind; q[r]=(ber[r+1][i]); r++; } assert(r<=m); for(;r<m;r++){ p[r]=0; q[r]=0; swap(s[x[r]],s[y[r]]); } for(int i = 0;i<r;i++){ swap(tp[p[i]],tp[q[i]]); } assert(r<=m); for(int i = 0;i<n;i++){ assert(tp[i]==i); } return r; }

Compilation message (stderr)

sorting.cpp: In function 'int findSwapPairs(int, int*, int, int*, int*, int*, int*)':
sorting.cpp:21:32: warning: conversion from 'long int' to 'int' may change value [-Wconversion]
   21 |         int ind = find(s,s+n,i)-s;
      |                   ~~~~~~~~~~~~~^~
#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...