STUDY/Go Lang

[Go / 백준 5597번] 과제 안 내신 분..?

Jexists 2024. 12. 8. 21:06

문제

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

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

입력

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

출력

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

예제 입력 1 복사

3
1
4
5
7
9
6
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30

예제 출력 1 복사

2
8

예제 입력 2 복사

9
30
6
12
10
20
21
11
7
5
28
4
18
29
17
19
27
13
16
26
14
23
22
15
3
1
24
25

예제 출력 2 복사

2
8

작성코드

package main

import (
	"fmt"
	"sort"
)

func main() {
	var submitCount = 28
	student := make([]int, submitCount+2)
	for i := 0; i < submitCount; i++ {
		var j int
		fmt.Scan(&j)
		student[j-1] = j
	}

	notSubmit := make([]int, 0, 2)

	for i, v := range student {
		if v == 0 {
			notSubmit = append(notSubmit, i+1)
		}
	}

	sort.Slice(notSubmit, func(i, j int) bool {
		return notSubmit[i] < notSubmit[j]
	})

	for _, v := range notSubmit {
		fmt.Println(v)
	}
}

다른사람 풀이 참고한 코드

package main

import (
	"fmt"
)

func main() {
	var submitCount = 28
	student := make([]int, submitCount+2)
	for i := 0; i < submitCount; i++ {
		var j int
		fmt.Scan(&j)
		student[j-1] = 1
	}

	for i, v := range student {
		if v == 0 {
			fmt.Println(i + 1)
		}
	}
}

[참고] https://do-v-ob.tistory.com/23