728x90

문제

동혁이는 나무 조각을 5개 가지고 있다. 나무 조각에는 1부터 5까지 숫자 중 하나가 쓰여져 있다. 또, 모든 숫자는 다섯 조각 중 하나에만 쓰여 있다.

동혁이는 나무 조각을 다음과 같은 과정을 거쳐서 1, 2, 3, 4, 5 순서로 만들려고 한다.

  1. 첫 번째 조각의 수가 두 번째 수보다 크다면, 둘의 위치를 서로 바꾼다.
  2. 두 번째 조각의 수가 세 번째 수보다 크다면, 둘의 위치를 서로 바꾼다.
  3. 세 번째 조각의 수가 네 번째 수보다 크다면, 둘의 위치를 서로 바꾼다.
  4. 네 번째 조각의 수가 다섯 번째 수보다 크다면, 둘의 위치를 서로 바꾼다.
  5. 만약 순서가 1, 2, 3, 4, 5 순서가 아니라면 1 단계로 다시 간다.

처음 조각의 순서가 주어졌을 때, 위치를 바꿀 때 마다 조각의 순서를 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 조각에 쓰여 있는 수가 순서대로 주어진다. 숫자는 1보다 크거나 같고, 5보다 작거나 같으며, 중복되지 않는다. 처음 순서는 1, 2, 3, 4, 5가 아니다.

출력

두 조각의 순서가 바뀔때 마다 조각의 순서를 출력한다.

예제 입력 1 복사

2 1 5 3 4

예제 출력 1 복사

1 2 5 3 4 1 2 3 5 4 1 2 3 4 5


입력으로 들어온 나무 조각의 길이를 버블정렬하는 문제이다. 

정렬중에 가장 간단한 정렬이고, 얼마전에 각 정렬을 정리해서 포스팅한 적이 있다. 

알고리즘 카테고리에 들어가면 버블, 선택, 삽입, 퀵, 머지정렬에 대한 설명과 코드를 볼 수 있다.

 

 

코드 원본 : https://github.com/chosh95/STUDY/blob/master/BaekJoon/2020/%EB%82%98%EB%AC%B4%20%EC%A1%B0%EA%B0%81.cpp

 

chosh95/STUDY

프로그래밍 문제 및 알고리즘 정리. Contribute to chosh95/STUDY development by creating an account on GitHub.

github.com

 

C++ 코드

#include <iostream>
#include <algorithm>
using namespace std;
int p[6];

int main()
{
	for (int i = 1; i <= 5; i++) cin >> p[i];

	for (int i = 5; i >= 1; i--) {
		for (int j = 1; j < i; j++) {
			if (p[j] > p[j+1]) {
				swap(p[j], p[j+1]);
				for (int k = 1; k <= 5; k++)
					cout << p[k] << " ";
				cout << endl;
			}
		}
	}
}
728x90

'알고리즘 > 백준' 카테고리의 다른 글

[백준] 카드 1 (2161번)  (0) 2020.05.02
[백준] A+B-9 (15740번)  (0) 2020.05.01
[백준] TV 크기 (1297번)  (0) 2020.05.01
[백준] 가운데를 말해요 (1655번)  (0) 2020.03.23
[백준] 이동하기 (11048번)  (0) 2020.03.23

+ Recent posts