ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [BAEKJOON] 5597 과제 안 내신 분..?
    알고리즘 2023. 11. 3. 11:44
    반응형

    문제

    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

    해당 문제는 리스트를 잘 알고 있는 지 확인을 하는 문제였다.

    반복문으로 리스트에 출석부를 미리 만들고 제거하는 식으로 하면 순차적으로 정렬을 안해도 된다.

    물론 입력한 것들을 차례대로 넣고 없는 것을 찾아도 되는 문제이기도 할 듯 하다.

     

    물론 나는 그렇게 안풀었다.

    ㅁ?ㄹ 해보고 댓글 남겨주길 바란다!

     

    import sys

    l = [i for i in range(1, 31)]

    print(l)
    for _ in range(28):
        n = int(sys.stdin.readline().strip())
        l.remove(n)

    print(l[0])
    print(l[1])

     

    처음에 이 코드로 제출했는데 안되서 뇌 정지 왔는데 알고보니 5번째 줄에 출력이 있더라고...

    매번 이런 가벼운 실수를 하는 것 같다...

    잘 확인하도록 하자

     

    import sys

    l = [i for i in range(1, 31)]

    for _ in range(28):
        n = int(sys.stdin.readline().strip())
        l.remove(n)

    print(l[0])
    print(l[1])

     

    여기서 l[0], l[1]로 출력하는 이유는 어쩌피 2개만 남고 앞에는 작은 숫자이기 때문이다.

    반응형

    '알고리즘' 카테고리의 다른 글

    [BAEKJOON] 10811 바구니 뒤집기  (2) 2023.11.03
    [BAEKJOON] 3052 나머지  (0) 2023.11.03
    [BAEKJOON] 10813 공 바꾸기  (0) 2023.11.03
    [BAEKJOON] 10810 공 넣기  (0) 2023.11.03
    [BAEKJOON] 10807 개수 세기  (0) 2023.11.03
Designed by Tistory.