답안 #1108000

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1108000 2024-11-02T14:43:51 Z Aviansh 정렬하기 (IOI15_sorting) C++17
16 / 100
51 ms 38436 KB
#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];
    iota(be,be+n,0);
    int ber[m][n];
    for(int i = m-1;i>=0;i--){
        swap(be[x[i]],be[y[i]]);
        int temp[n];
        for(int i = 0;i<n;i++){
            temp[be[i]]=i;
        }
        copy(temp,temp+n,ber[i]);
    }
    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++;
    }
    for(;r<m;r++){
        p[r]=0;
        q[r]=0;
        swap(s[x[r]],s[y[r]]);
    }
    for(int i = 0;i<n;i++){
        assert(s[i]==i);
    }
	return r;
}


Compilation message

sorting.cpp: In function 'int findSwapPairs(int, int*, int, int*, int*, int*, int*)':
sorting.cpp:13:17: warning: declaration of 'i' shadows a previous local [-Wshadow]
   13 |         for(int i = 0;i<n;i++){
      |                 ^
sorting.cpp:10:13: note: shadowed declaration is here
   10 |     for(int i = m-1;i>=0;i--){
      |             ^
sorting.cpp:21:32: warning: conversion from 'long int' to 'int' may change value [-Wconversion]
   21 |         int ind = find(s,s+n,i)-s;
      |                   ~~~~~~~~~~~~~^~
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 336 KB Output is correct
2 Correct 0 ms 336 KB Output is correct
3 Correct 1 ms 336 KB Output is correct
4 Incorrect 1 ms 336 KB Output isn't correct
5 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 336 KB Output is correct
2 Correct 0 ms 336 KB Output is correct
3 Correct 1 ms 336 KB Output is correct
4 Incorrect 1 ms 336 KB Output isn't correct
5 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 336 KB Output is correct
2 Correct 1 ms 336 KB Output is correct
3 Correct 3 ms 1360 KB Output is correct
4 Correct 3 ms 1616 KB Output is correct
5 Correct 2 ms 1616 KB Output is correct
6 Correct 1 ms 336 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 336 KB Output is correct
2 Correct 0 ms 336 KB Output is correct
3 Correct 1 ms 336 KB Output is correct
4 Incorrect 1 ms 336 KB Output isn't correct
5 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 51 ms 38436 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 51 ms 38436 KB Output isn't correct
2 Halted 0 ms 0 KB -