본문 바로가기

컴퓨터 과학/자료구조, 알고리즘

[Rust로 백준 하루 하나] 4-7. 과제 안 내신 분..?

문제 (5597번)

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

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

 

입력

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

 

출력

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


풀이

코드

use std::io;

fn main() {
    let mut students = [0; 30];
    // println!("{:?}", students);
    let mut input = String::new();

    for _ in 0..28 {
        io::stdin().read_line(&mut input).unwrap();
    }

    let submitted: Vec<&str> = input.split_whitespace().collect();

    for i in submitted.iter() {
        let index: usize = i.trim().parse().unwrap();
        students[index-1] = 1;
    }

    for i in 0..30 {
        if students[i]==0 {
            println!("{}", i+1);
        }
    }
}

해설

특이사항 없음


추가 학습

  • 특이사항 없음