👩‍💻 알고리즘/🔠 C

백준 5597

오브 🧙‍♂️ 2024. 2. 11. 01:37

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

 

5597번: 과제 안 내신 분..?

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

www.acmicpc.net

문제

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

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

입력

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

출력

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

 

#include <stdio.h>

int main()
{
    int arr[30] = {0,}; //배열30개 0으로 초기화
    
    for(int i=0;i<28;i++) //28번 반복 입력받음
    {
        int n;
        scanf("%d",&n); //입력받음
        arr[n-1] = 1; //5를 입력했을 때 인덱스값은 4임으로. 입력받은 인덱스값은 1로 변환
    }
   
    for(int i=0;i<30;i++) //30번 반복 체크
    {
        if(arr[i]==0) //만약 인덱스값이 0이면? 입력은 못받은 것
      
            printf("%d\n",i+1); //위와 동일.인덱스값이 4라면 들어가있는 값은 5임으로 +1을 해줌
        
    }
}

 

코드 해석

배열 문제.

엑셀에 1~30까지 칸을 0으로 채워두고, 입력받은 값은 1로 채운다음에 0인 녀석들을 찾아내는 알고리즘이다.