본문 바로가기

C++/백준

[C++][백준] [정렬] 2750 수 정렬하기

https://www.acmicpc.net/problem/2750

 

2750번: 수 정렬하기

첫째 줄에 수의 개수 N(1 ≤ N ≤ 1,000)이 주어진다. 둘째 줄부터 N개의 줄에는 숫자가 주어진다. 이 수는 절댓값이 1,000보다 작거나 같은 정수이다. 수는 중복되지 않는다.

www.acmicpc.net

문제

N개의 수가 주어졌을 때, 이를 오름차순으로 정렬하는 프로그램을 작성하시오.

입력

첫째 줄에 수의 개수 N(1 ≤ N ≤ 1,000)이 주어진다. 둘째 줄부터 N개의 줄에는 숫자가 주어진다. 이 수는 절댓값이 1,000보다 작거나 같은 정수이다. 수는 중복되지 않는다.

출력

첫째 줄부터 N개의 줄에 오름차순으로 정렬한 결과를 한 줄에 하나씩 출력한다.

예제 입력 1

5

5

2

3

4

1

예제 출력 1

1

2

3

4

5

 

삽입정렬을 이용해서 문제를 풀었다.

주어진 수를 정렬하면 되는 간단한 문제이다.

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#include <stdio.h>
#include <stdlib.h>
#define swap(x,y,tmp)((tmp)=(x),(x)=(y),(y)=(tmp))
 
int main(){
    int N;
    int list[1000];
    scanf("%d"&N);
    for(int i=0; i<N; i++)
        scanf("%d"&list[i]);
 
    int least, tmp, j;
    for(int i=0; i<N-1; i++){
        least=i;
        for(j=i+1; j<N; j++)
            if(list[j] < list[least])
                least=j;
        if(i!=least)
            swap(list[i],list[least],tmp);
    }
 
    for(int i=0; i<N; i++)
        printf("%d\n", list[i]);
 
http://colorscripter.com/info#e" target="_blank" style="color:#4f4f4ftext-decoration:none">Colored by Color Scripter
 

 

'C++ > 백준' 카테고리의 다른 글

[C++][백준] 2753 윤년  (0) 2020.03.10
[C++][백준] [정렬] 2751 수 정렬하기 2  (0) 2020.03.10
[C++][백준] 2742 기찍 N  (0) 2020.03.10
[C++][백준] 2741 N 찍기  (0) 2020.03.10
[C++][백준] 2739 구구단  (0) 2020.03.10