분류 전체보기
[프로그래머스] 코딩테스트연습 > 신규아이디 추천
코딩테스트 연습 - 신규 아이디 추천 카카오에 입사한 신입 개발자 네오는 "카카오계정개발팀"에 배치되어, 카카오 서비스에 가입하는 유저들의 아이디를 생성하는 업무를 담당하게 되었습니다. "네오"에게 주어진 첫 업무는 새로 programmers.co.kr function solution(new_id) { let answer = new_id .toLowerCase() // 1. 대문자 => 소문자 .replace(/[^a-z0-9-_.]/g, "") // 2. 형식x 문자 제거 .replace(/\.+/g, ".") // 3. 마침표 2개 이상 => 1개 .replace(/^\.|\.$/g, "") // 4. 처음이나 마지막 마침표 제거 // 5. 빈문자열 => 'a' if(answer === ''){ an..
[프로그래머스] 코딩테스트연습 > 로또의 최고 순위와 최저 순위
코딩테스트 연습 - 로또의 최고 순위와 최저 순위 로또 6/45(이하 '로또'로 표기)는 1부터 45까지의 숫자 중 6개를 찍어서 맞히는 대표적인 복권입니다. 아래는 로또의 순위를 정하는 방식입니다. 1 순위 당첨 내용 1 6개 번호가 모두 일치 2 5개 번호 programmers.co.kr function solution(lottos, win_nums) { const exceptZero = lottos.filter(number => number !== 0) const numZero = lottos.filter(number => number ===0).length const match = exceptZero.filter(number => win_nums.includes(number)).length let..
[프로그래머스] 코딩테스트연습 > 완전탐색 > 모의고사
코딩테스트 연습 - 모의고사 수포자는 수학을 포기한 사람의 준말입니다. 수포자 삼인방은 모의고사에 수학 문제를 전부 찍으려 합니다. 수포자는 1번 문제부터 마지막 문제까지 다음과 같이 찍습니다. 1번 수포자가 찍는 programmers.co.kr function solution(answers) { const stu1 = [1,2,3,4,5] const stu2 = [2,1,2,3,2,4,2,5] const stu3 = [3,3,1,1,2,2,4,4,5,5] let answer = [] const result1 = answers.filter((answer, idx) => answer === stu1[idx % stu1.length]).length const result2 = answers.filter((a..
[프로그래머스] 코딩테스트연습 > 정렬 > K번째 변수
https://programmers.co.kr/learn/courses/30/lessons/42748 코딩테스트 연습 - K번째수 [1, 5, 2, 6, 3, 7, 4] [[2, 5, 3], [4, 4, 1], [1, 7, 3]] [5, 6, 3] programmers.co.kr function solution(array, commands) { const arr = commands.map((el) => { // const start = el[0] // const end = el[1] // const position = el[2] const [start, end, position] = el //문자열이 아니므로 sort 정렬순서 지정 const result = array.slice(start-1,end)...
[프로그래머스] 코딩테스트연습 > 스택/큐 > 기능개발
https://programmers.co.kr/learn/courses/30/lessons/42586 코딩테스트 연습 - 기능개발 프로그래머스 팀에서는 기능 개선 작업을 수행 중입니다. 각 기능은 진도가 100%일 때 서비스에 반영할 수 있습니다. 또, 각 기능의 개발속도는 모두 다르기 때문에 뒤에 있는 기능이 앞에 있는 programmers.co.kr function solution(progresses, speeds) { let answer = [0]; const remainingDay = progresses.map((el, idx) => Math.ceil((100-el)/speeds[idx]) ) let maxDay = remainingDay[0] for(let i=0, j=0; i
[프로그래머스] 코딩테스트연습 > 해시 > 위장
https://programmers.co.kr/learn/courses/30/lessons/42578 코딩테스트 연습 - 위장 programmers.co.kr function solution(clothes) { return Object.values(clothes.reduce((obj, t)=> { obj[t[1]] = obj[t[1]] ? obj[t[1]] + 1 : 1; return obj; } , {})).reduce((a,b)=> a*(b+1), 1)-1; } 풀다가 간단하게 어떻게 푸는지 모르겠어서 인터넷 찾아보고 답을 찾아서 풀었다... clothes 에서 각각의 key 값 검색 ( t[1] ) 빈 object( 초기값: {} ) 에 기존 key 값( 해당하는 옷 종류 )이 존재하면 개수를 +1..
[프로그래머스] 코딩테스트연습 > 해시 > 완주하지 못한 선수
https://programmers.co.kr/learn/courses/30/lessons/42576 코딩테스트 연습 - 완주하지 못한 선수 수많은 마라톤 선수들이 마라톤에 참여하였습니다. 단 한 명의 선수를 제외하고는 모든 선수가 마라톤을 완주하였습니다. 마라톤에 참여한 선수들의 이름이 담긴 배열 participant와 완주한 선수 programmers.co.kr function solution(participant, completion) { let parti = participant.sort() let comp = completion.sort() for(let i=0; i