ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • 5597번 과제 안 내신 분..?
    백준 코딩테스트/1차원 배열 2024. 10. 23. 17:27

    문제

    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

     

     

    student = [s + 1 for s in range(30)]

    for i in range(28):
        student.remove(int(input()))

    print(min(student))
    print(max(student))

     

    답은 이러한데, 내가 pop() 함수를 썼었다 원래는 그래서 틀렸다.

    이유는 pop()은 리스트에 대한 index 번호, 위치로 삭제하는데, 4번을 pop하고 나서 10번을 pop하게 되면 10번의 위치는 4번이 pop된 이후여서 위치 값이 -1 줄었다. 이런식으로 위치의 값이 삭제될때마다 변하므로 pop()은 쓰면 안되고,

    값을 지정해서 확실하게 삭제하는 remove()를 사용해여한다.

    '백준 코딩테스트 > 1차원 배열' 카테고리의 다른 글

    10811번 바구니  (1) 2024.10.24
    3052번 나머지  (0) 2024.10.23
    10813번 공 바꾸기  (0) 2024.10.23
    10810번 공 넣기  (0) 2024.10.23
    2562번 최댓값  (0) 2024.10.23
Designed by Tistory.