Skip to content

Commit

Permalink
24/04/12 알고리즘 수업 - 버블 정렬 3
Browse files Browse the repository at this point in the history
  • Loading branch information
makehard23 committed Apr 12, 2024
1 parent 6397334 commit 0591b50
Showing 1 changed file with 58 additions and 0 deletions.
58 changes: 58 additions & 0 deletions yuyu0830/정렬/23970.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#include <iostream>

#define fastio cin.tie(NULL); cin.sync_with_stdio(false);

using namespace std;

int arr[2][10001] = {0, };
int n, arrPtr = 0;

bool same() {
// start at 'arrPtr'
for (int i = arrPtr; i < n; i++) {
// if diff, terminate this function
if (arr[0][i] != arr[1][i]) return false;
// if same, then that index will same forever. no reason to compare again.
arrPtr++;
}
return true;
}

int main() {
fastio
cin >> n;
for (int i = 0; i < 2; i++)
for (int j = 0; j < n; j++)
cin >> arr[i][j];

int rnd = n - 1, ptr = 0;

// it can be same before sort
if (same()) {
printf("1\n");
return 0;
}

while (rnd) {
// sort [0] to [ptr - rnd]
int a = arr[0][ptr];
int b = arr[0][ptr + 1];

arr[0][ptr] = min(a, b);
arr[0][ptr + 1] = max(a, b);

// if this index is last index in this round
if (++ptr == rnd) {
// next round
ptr = 0;
rnd--;
}

if (same()) {
// if arr is same
printf("1\n");
return 0;
}
}
printf("0\n");
}

0 comments on commit 0591b50

Please sign in to comment.