본문 바로가기

분류 전체보기85

백준 2738번 백준 2738번을 풀어보았다.let [NM, ...input] = require('fs').readFileSync('/dev/stdin').toString().split('\n')let [N, M] = NM.split(' ').map(Number)input = input.map((value) => value.trim().split(' ').map(Number))let output = ''for (let i = 0; i  결국 해결하긴 했지만 얼렁뚱땅 풀다보니 시행착오를 많이 겪었다. 1. 자료형에 유의하자. 처음에는 위 코드의 두 번째 줄과 세 번째 줄을 아래와 같이 작성하였고let [N, M] = NM.split(' ')input = input.map((value) => value.trim().spli.. 2024. 12. 30.
백준 10988번 백준 10988번을 풀어보았다.let input = require('fs').readFileSync('/dev/stdin').toString().trim()input === input.split('').reverse().join('') ? console.log(1) : console.log(0) split, reverse, join 메소드를 사용하면 간단하게 해결할 수 있다.split(separator): 문자열을 지정한 구분자를 기준으로 나눈다.reverse(): 배열의 순서를 반전한다.참고) 백준 10811번, 백준 2908번join(separator): 배열의 모든 요소를 지정한 구분자로 연결하여 하나의 문자열을 만든다. 그러나 메소드를 사용하지 않고 문자열의 시작과 끝을 순서대로 비교해서도 해결할.. 2024. 12. 30.
백준 2444번 백준 2444번을 풀어보았다.let N = Number(require('fs').readFileSync('/dev/stdin').toString())let output = ''for (let i = 0; i i; j--) { output += ' ' } for (let k = 0; k  위와 같이 규칙을 파악하고 반복문을 사용하여 풀이하였으나 repeat 메소드를 사용하면 더 간단하게 해결할 수 있다. 참고) 백준 25314번, 백준 2675번let N = Number(require('fs').readFileSync('/dev/stdin').toString())let output = ''for (let i = 0; i  💫 이 문제를 통해 배운 것문자열을 반복할 때 repeat 메소드도 떠올.. 2024. 12. 30.
백준 3003번 백준 3003번을 풀어보았다.let input = require('fs').readFileSync('/dev/stdin').toString().split(' ').map(Number)const set = [1, 1, 2, 2, 2, 8]let output = ''for (let i = 0; i  올바른 세트에서 동혁이가 갖고 있는 개수를 뺀 값을 output에 추가해주었다. map 메소드를 사용해서 풀이할 수도 있다.let input = require('fs').readFileSync('/dev/stdin').toString().split(' ').map(Number)const set = [1, 1, 2, 2, 2, 8]input = input.map((value, index) => set[index] .. 2024. 11. 15.
백준 5622번 백준 5622번을 풀어보았다.let words = require('fs').readFileSync('/dev/stdin').toString().trim()let time = 0for (const word of words) { if (word  이 문제의 핵심은 알파벳별로 소요 시간을 구분해야 한다는 것이다. O까지는 3개의 알파벳이 하나의 소요 시간으로 매핑되므로 알파벳의 유니코드값과의 관계를 찾아 소요 시간을 구하였고 그 이후로는 각각 소요 시간이 8, 9, 10인 경우로 처리해주었다. 처음에는 words를 입력받는 문장에 trim 메소드를 사용하지 않았는데 이상하게 계속 틀렸다고 나와서 혹시 몰라 trim 메소드를 사용해보니 그제서야 정답으로 처리되었다. 종종 백준에서 실행 시 입력값 뒤에 \n 등.. 2024. 11. 15.
백준 2908번 백준 2908번을 풀어보았다.let [A, B] = require('fs').readFileSync('/dev/stdin').toString().split(" ")let A_reversed = 0, B_reversed = 0for (let i = 2; i >= 0; i--) { A_reversed += A[i] * (10 ** i) B_reversed += B[i] * (10 ** i)}console.log(A_reversed > B_reversed ? A_reversed : B_reversed) 이 문제는 크게 역순으로 만드는 단계와 출력하는 단계로 구분할 수 있는데, 각 단계별 풀이를 정리해보았다. 역순 만들기 ① 반복문 위와 같이 반복문을 사용해 일의 자리, 십의 자리, 백의 자리를 A_reve.. 2024. 11. 15.