티스토리 뷰

728x90
반응형

목차

     

    문제

     

    X대학 M교수님은 프로그래밍 수업을 맡고 있다. 

    교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.

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

     

    입력

     

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

     

    출력

     

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

     

    풀이

     

    자바로 풀 땐 스트림으로, 파이썬으로 풀 땐 제출한 사람을 하나씩 지워가며 풀었던 문제이다.

     

    자바스크립트로 풀 때는 큰 의미는 없지만 두 가지 방식으로 풀이했는데,

     

    공통적으로는 1부터 30까지 배열에 넣은 뒤

     

    1. 첫 번째 방법은 제출한 사람의 번호를 인덱스로 가진 값을 0으로 바꾼 뒤,
      마지막에 함수 체이닝으로 0인 숫자를 제거하고 남은 값을 출력하는 것이다.
    2. 두 번째 방법은 파이썬으로 풀 때와 마찬가지로 제출한 사람의 번호를 인덱스로 가진 요소를 하나씩 제거한 뒤 출력하는 것이다.

    그냥 불러서 쓸 수 있는 메서드 체이닝이 자바의 스트림을 다루는 것 같아 재미있었다.

     

    지난 문제에 나왔던 배열 초기화와, 메서드 체이닝을 통해 배열을 가공하는 것을 배웠다.

     

    JavaScript-1

     

    const rl = require('readline').createInterface({
        input: process.stdin,
        output: process.stdout,
    });
    
    let input = Array.from({ length: 30 }, (_, index) => index + 1);
    
    rl.on('line', (line) => {
        input[parseInt(line) - 1] = 0;
    }).on('close', () => {
        input.filter((a) => a !== 0).forEach((a) => console.log(a));
        process.exit(0);
    });

     

    JavaScript-2

     

    const rl = require('readline').createInterface({
        input: process.stdin,
        output: process.stdout,
    });
    
    let input = Array.from({ length: 30 }, (_, index) => index + 1);
    
    rl.on('line', (line) => {
        const complete = Number(line);
        input = input.filter((n) => n !== complete);
    }).on('close', () => {
        input.forEach((a) => console.log(a));
        process.exit(0);
    });

     

    Performance

     

    놀라울 정도로 성능이 비슷했다. 당연하다면 당연한 일인가.

    반응형
    댓글
    공지사항
    최근에 올라온 글
    최근에 달린 댓글
    Total
    Today
    Yesterday
    링크
    «   2024/06   »
    1
    2 3 4 5 6 7 8
    9 10 11 12 13 14 15
    16 17 18 19 20 21 22
    23 24 25 26 27 28 29
    30
    글 보관함