[C]백준_5597 : 과제 안 내신 분..?

Alal11·2023년 3월 2일
0
post-thumbnail

출처

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


문제

X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.

교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.


입력

입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.


출력

출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.


예제 입출력


알고리즘 분류

  • 구현

➡️문제 분석

배열을 이용하여 입력을 받고 문제를 해결한다.


➡️코드(⭕)

#include <stdio.h>

int main()
{
	int arr[31] = { 0 };
	int i, num;

	for (i = 1; i <= 28; i++)
	{
		scanf("%d", &num);
		arr[num] = num;
	}

	for (i = 1; i < 31; i++)
	{
		if (arr[i] == 0)
		{
			printf("%d\n", i);
		}
	}
}

➡️코드 분석

  1. 학생이 30명까지 있으니까 배열의 크기는 NULL 값을 포함해서 31로 해주고 0으로 초기화 해준다.

  2. for문으로 출석번호 28개를 입력받고, 그 값을 배열 arr의 인덱스로 하여 해당 값으로 넣어준다.

  3. for문으로 1부터 30까지 arr의 인덱스로 하는 요소 값이 0이라면 출석을 부르지 않은게 되므로 그 값인 i를 출력해준다.


➡️end

예전에 풀어놓은 문제 이제서야 포스팅 한다!ㅋㅋㅋ 그래도 코드 분석을 하느라 한 번 더 문제를 풀어보는 느낌이라 좋다ㅎ_ㅎ 배열을 이용하여 인덱스와 요소 값을 일치시켜서 푸는 아이디어가 좋았다.

0개의 댓글