반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- dataFetching
- Erricson
- React.js
- BOJ
- Girls_In_ICT
- 객체인지
- 이미지스캔
- getDerivedStateFromProps
- props
- 에릭슨엘지
- ts
- props.key
- js
- next
- filter
- Bestawards
- Baekjoon
- 백준
- GirlsInICT해커톤
- javascript
- 코드캠프
- Unmounting
- 15721
- 자바스크립트
- axios
- map
- nodejs
- react
- typescript
- 훈훈한자바스크립트
Archives
- Today
- Total
민희의 코딩일지
[JS] 백준 5597번 과제 안 내신 분..? 본문
반응형
https://www.acmicpc.net/problem/5597
5597번: 과제 안 내신 분..?
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다. 교수님이 내준 특별과제를 28명이 제출했는데,
www.acmicpc.net
문제
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
풀이
학생 출석번호 1-30이 모두 들어있는 배열 arr을 준비하고, 특별 과제를 제출한 학생의 출석번호가 들어있는 배열 InputArr을 만든다. arr에서 inputArr 에 속한 학생은 모두 제거해준다. 제거해준 학생은 배열에서 undefined 처리된다. type 이 undefined가 아닌 학생 배열에 남아있는 출석번호를 출력해주면 된다.
코드
const fs = require("fs");
let input = fs.readFileSync("/dev/stdin").toString().split("\n");
let arr = [];
for (let i=1; i<=30; i++) {
arr.push(i);
}
let inputArr = [];
for (let i=0; i<input.length; i++) {
inputArr.push(parseInt(input[i]));
}
function solution(arr, inputArr){
for (let i=0; i<30; i++) {
for (let j=0; j<inputArr.length; j++) {
if (arr[i] === inputArr[j]) delete arr[i];
}
}
for (let i=0; i<arr.length; i++) {
if (typeof arr[i] !== 'undefined'){
console.log(arr[i]);
}
}
}
solution(arr, inputArr);
반응형
'자료구조, 알고리즘 > 자바스크립트' 카테고리의 다른 글
[JS] Learning JavaScript Data Structures and Algorithms 2장.배열 (0) | 2023.01.07 |
---|---|
[JS] 백준 4344번 평균은 넘겠지 (0) | 2023.01.02 |
[JS] 백준 1546번 평균 (0) | 2023.01.01 |
[JS] 백준 3052번 나머지 (0) | 2023.01.01 |
Comments