-
[프로그래머스] 다음 큰 숫자Algorithm 2021. 4. 3. 18:23
programmers.co.kr/learn/courses/30/lessons/12911
코딩테스트 연습 - 다음 큰 숫자
자연수 n이 주어졌을 때, n의 다음 큰 숫자는 다음과 같이 정의 합니다. 조건 1. n의 다음 큰 숫자는 n보다 큰 자연수 입니다. 조건 2. n의 다음 큰 숫자와 n은 2진수로 변환했을 때 1의 갯수가 같습니
programmers.co.kr
더보기문제 설명
자연수 n이 주어졌을 때, n의 다음 큰 숫자는 다음과 같이 정의 합니다.
- 조건 1. n의 다음 큰 숫자는 n보다 큰 자연수 입니다.
- 조건 2. n의 다음 큰 숫자와 n은 2진수로 변환했을 때 1의 갯수가 같습니다.
- 조건 3. n의 다음 큰 숫자는 조건 1, 2를 만족하는 수 중 가장 작은 수 입니다.
예를 들어서 78(1001110)의 다음 큰 숫자는 83(1010011)입니다.
자연수 n이 매개변수로 주어질 때, n의 다음 큰 숫자를 return 하는 solution 함수를 완성해주세요.
제한 사항
- n은 1,000,000 이하의 자연수 입니다.
입출력 예
n result 78 83 15 23 입출력 예 설명
입출력 예#1
문제 예시와 같습니다.
입출력 예#2
15(1111)의 다음 큰 숫자는 23(10111)입니다.풀이
- 2진수 변환: toString(2)
- 2진수로 변환하였을 때 1의 갯수 체크
- n 다음 숫자부터 2진수로 변환하면서 1의 갯수가 같은 값이 나오면 리턴
// 조건 만족하는 숫자 찾음 function solution(n) { var temp = checkOne(n); var answer = ''; // n 다음 숫자부터 시작 / 1,000,000 이하 자연수까지 찾음 for(let i = n + 1; i <= 1000000; i++) { answer = checkOne(i); if(temp === answer) { return i; } } } // 2진수 변환, 1의 갯수 반환 function checkOne(n) { var count = 0; var str = n.toString(2); for(let i = 0; i < str.length; i++) { if(str[i] === '1') { count++; } } return count; }
'Algorithm' 카테고리의 다른 글
[프로그래머스] 124 나라의 숫자 (0) 2021.04.08 [프로그래머스] 신규 아이디 추천 (0) 2021.04.04 [프로그래머스] 올바른 괄호 (0) 2021.04.02 [Codewars] Stop gninnipS My sdroW! (0) 2021.04.01 [프로그래머스] 기능개발 (0) 2021.03.30