[C언어 코드업 문제풀이] CodeUp 1425 : 자리 배치
코드업 1425번 자리 배치 문제 풀이 해답입니다.
1. 문제 설명
A중학교에 첫 발령을 받은 B교사는 1학년 1반 담임을 맡게 되었다.
기대를 안고 첫 출근한 B교사는 너무 설렌 나머지 학생들이 등교하기도 전에 교실에 가서 학생들이 오기만을 기다리고 있었다.
그리고 제일 먼저 무슨 일을 해야 될지 생각하던 중 학생들 자리 배치를 우선적으로 해야겠다고 생각했다.
여러 가지 자리 배치 방법을 고려하다가 학생들의 키가 작은 순서대로 앞에서부터 앉히는 것이 제일 좋은 방법이라고 결정하게 되었다.
예를 들어, 160, 165, 164, 165, 150, 165, 168, 145, 170의 학생들 키가 주어지고 한 줄에 6명씩 앉는다면 다음과 같이 앉으면 될 것이다.
145 | 150 | 160 | 164 | 165 | 165 |
165 | 168 | 170 |
왼쪽 위부터 차례대로 키 순서대로 앉으며 한 줄이 다 찼을 경우 다음 줄로 넘어간다. 다음 줄도 마찬가지로 왼쪽부터 채운다.
이와 같이 학생의 키순서대로 자리를 배치하는 프로그램을 작성하시오.
2. 입력
1. 첫 번째 줄에 학생 수(N)와 한줄에 앉을 수 있는 자리수(C)가 자연수로 주어진다. 단, (1≤N≤99), (1≤C≤10)
2. 둘째 줄에는 N명의 학생 키들이 공백으로 구분되어 입력된다.
3. 출력
학생들의 자리 배치 결과를 공백으로 분리하여 출력한다.
(표현오류 조심 : 각 행의 마지막에 공백을 한 칸 넣어야 됨.)
4. 입력 예시
9 6
160 165 164 165 150 165 168 145 170
5. 출력 예시
145 150 160 164 165
165 165 168 170
6. 문제 풀이
#include<stdio.h>
int main(){
int N,C;
scanf("%d %d",&N,&C);
int Buf[99] = {};
for(int i = 0; i < N; i++){
scanf("%d",&Buf[i]);
}
int temp;
for(int i = 0 ; i < N ; i ++) {
for(int j = 0 ; j < N -i -1 ; j ++) {
if(Buf[j]>Buf[j+1]) {
temp = Buf[j];
Buf[j] = Buf[j+1];
Buf[j+1] = temp;
}
}
}
int k = 0;
for(int j = 0; j < N; j++){
printf("%d ",Buf[j]);
k++;
if(C == k){
printf("\n");
k=0;
}
}
return 0;
}
|
for(int i = 0 ; i < N ; i ++) {
for(int j = 0 ; j < N -i -1 ; j ++) {
if(Buf[j]>Buf[j+1]) {
temp = Buf[j];
Buf[j] = Buf[j+1];
Buf[j+1] = temp;
}
}
}
로 입력받은 신장을 오름차순 정렬해줍니다.
for(int j = 0; j < N; j++){
printf("%d ",Buf[j]);
k++;
if(C == k){
printf("\n");
k=0;
}
그 후 한줄에 앉을 수 있는 자리수(C) 만큼 printf("\n"); 을 이용해 줄을 넘겨줍니다.
'ET의 공부 > C언어 연습문제[ 코드업 ]' 카테고리의 다른 글
[C언어 코드업 문제풀이] CodeUp 1440 : 비교 (0) | 2020.04.13 |
---|---|
[C언어 코드업 문제풀이] CodeUp 1430 : 기억력 테스트 2 (3) | 2020.04.07 |
[C언어 코드업 문제풀이] CodeUp 1420 : 3등 찾기 (0) | 2020.04.07 |
[C언어 코드업 문제풀이] CodeUp 1416 : 2진수 변환 (0) | 2020.04.07 |
[C언어 코드업 문제풀이] CodeUp 1412 : 알파벳 개수 출력하기 (1) | 2020.04.07 |