Sapphire9 개발 일지
프로그래머스 - 유사 칸토어 비트열 (JavaScript)
알고리즘/기타 2023. 4. 25. 19:28

문제 https://school.programmers.co.kr/learn/courses/30/lessons/148652 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 생각해보기 n = 1인 유사 칸토어 비트열을 만들기 위한 연산 횟수 : 1번 n = 2인 유사 칸토어 비트열을 만들기 위한 연산 횟수 : 1 + 5^1번 n = 3인 유사 칸토어 비트열을 만들기 위한 연산 횟수 : 1 + 5^1번 + 5^2번 n번째 유사 칸토어 비트열을 만들기 위해서는 1 + 5^1 + ... + 5^(n - 1)번의 연산이 필요하다. 또한, 해당 비트열 안에서 1의 개수..

프로그래머스 - 인사고과 (JavaScript)
알고리즘/기타 2023. 3. 28. 22:41

문제 완호네 회사는 연말마다 1년 간의 인사고과에 따라 인센티브를 지급합니다. 각 사원마다 근무 태도 점수와 동료 평가 점수가 기록되어 있는데 만약 어떤 사원이 다른 임의의 사원보다 두 점수가 모두 낮은 경우가 한 번이라도 있다면 그 사원은 인센티브를 받지 못합니다. 그렇지 않은 사원들에 대해서는 두 점수의 합이 높은 순으로 석차를 내어 석차에 따라 인센티브가 차등 지급됩니다. 이때, 두 점수의 합이 동일한 사원들은 동석차이며, 동석차의 수만큼 다음 석차는 건너 뜁니다. 예를 들어 점수의 합이 가장 큰 사원이 2명이라면 1등이 2명이고 2등 없이 다음 석차는 3등부터입니다. 각 사원의 근무 태도 점수와 동료 평가 점수 목록 scores이 주어졌을 때, 완호의 석차를 return 하도록 solution 함..

프로그래머스 - 시소 짝꿍 (JavaScript)
알고리즘/기타 2023. 3. 19. 18:53

문제 설명 어느 공원 놀이터에는 시소가 하나 설치되어 있습니다. 이 시소는 중심으로부터 2(m), 3(m), 4(m) 거리의 지점에 좌석이 하나씩 있습니다. 이 시소를 두 명이 마주 보고 탄다고 할 때, 시소가 평형인 상태에서 각각에 의해 시소에 걸리는 토크의 크기가 서로 상쇄되어 완전한 균형을 이룰 수 있다면 그 두 사람을 시소 짝꿍이라고 합니다. 즉, 탑승한 사람의 무게와 시소 축과 좌석 간의 거리의 곱이 양쪽 다 같다면 시소 짝꿍이라고 할 수 있습니다. 사람들의 몸무게 목록 weights이 주어질 때, 시소 짝꿍이 몇 쌍 존재하는지 구하여 return 하도록 solution 함수를 완성해주세요. 제한 사항 2 ≤ weights의 길이 ≤ 100,000 100 ≤ weights[i] ≤ 1,000 몸..

구름 LEVEL - 단어의 개수 세기 (JavaScript)
알고리즘/기타 2023. 2. 11. 00:34

생각해보기 문자열 양 끝의 공백과 문자열 사이 여러 개의 공백을 고려해야 한다. 또한 입력 문자열이 공백일 경우에 대한 예외 처리가 필요하다. 풀이) // Run by Node.js const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout }); let str; function wordsCount (str) { const words = str.trim().replace(/ +/g, ' '); // +는 1개 이상의 문자 패턴, 글로벌(g) if (words.length == 0) return console.log('0'); wordList = wo..

구름 LEVEL - 근묵자흑 (JavaScript)
알고리즘/기타 2023. 2. 10. 23:58

생각해보기 K = 2 : N = 2, 3, 4, ... K = 3 : N = 3, 4, 5, ... 반복 시행을 통해 규칙성을 찾을 수 있다. 풀이) // Run by Node.js const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout }); const solution = (data) => { const [N, K] = data[0].split(' ').map(Number); console.log(Math.ceil((N - K)/(K - 1) + 1)); } let data = []; rl.on("line", function(line) { if..

검색 태그