https://school.programmers.co.kr/learn/courses/30/lessons/70129
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
function solution(s) {
let cnt = 0; // 이진 변환 횟수
let zeroCnt = 0; // 제거된 0의 개수
while (s.length !== 1) {
let beforeX = s.length;
s = s.replace(/0/g, "");
let afterX = s.length;
zeroCnt += (beforeX - afterX)
s = afterX.toString(2);
cnt++;
}
return [cnt, zeroCnt];
}
***
0 제거 전의 s 길이를 beforeX에 넣고,
replace를 사용하여 0을 제거한 s 길이를 afterX에 넣는다.
두 값의 차가 제거된 0의 개수이므로 zeroCnt에 더하고
toString 메서드를 사용하여 변경된 문자열의 길이를 2진법으로 변환한다.
그리고 이진 변환 횟수에 1을 더한다.
***
while문을 사용항 입력받은 문자열 s가 1일 때까지 위 과정을 반복해주었다.
그리고 이진 변환 횟수와 제거된 0의 개수를 넣은 배열을 return 해주었다.
'코딩테스트 > Programmers' 카테고리의 다른 글
진료순서 정하기 (JS) (1) | 2022.12.06 |
---|---|
최빈값 구하기 (JS) (0) | 2022.12.04 |
올바른 괄호 (JS) (0) | 2022.09.13 |
JadenCase 문자열 만들기 (JS) (1) | 2022.09.12 |
최댓값과 최솟값 (JS) (1) | 2022.09.12 |