반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- softeer
- 싸피
- 인턴십
- SQL
- 퍼즐 조각 채우기
- 정기 코딩 인증평가
- 핵심
- 등산코스 정하기
- 후기
- 프로그래머스
- 카카오코드 본선
- 산 모양 타일링
- 14942
- 티스토리챌린지
- 오블완
- 카카오
- SSAFY
- 배열 돌리기 5
- 소프티어
- 142085
- 백준
- 24955
- 숫자 이어 붙이기
- MySQL
- 설명
- 수료
- 해결
- 10기
- java
- PCCP
Archives
- Today
- Total
개발 쥬스
[프로그래머스/Java] 70129 이진 변환 반복하기 본문
반응형
🔗 문제 링크: https://school.programmers.co.kr/learn/courses/30/lessons/70129
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
🔍 해결 과정
해결 과정의 구상은 다음과 같습니다.
1️⃣ String의 replaceAll() 함수의 기능을 활용하여 문자열 s에서 0을 제거한다.
2️⃣ 0을 제거한 개수를 구하기 위해서 변환 전 문자열의 길이에서 변환 후 문자열의 길이의 차이를 구한다.
3️⃣ 변환 후의 문자열의 길이를 이진법으로 나타낸다.
4️⃣ 나타낸 이진법이 "1"과 같지 않다면 1️⃣ 부터 3️⃣까지의 과정을 반복한다.
✏️ 코드
class Solution {
public int[] solution(String s) {
int[] answer = new int[2];
int count = 0;
int zero = 0;
while (!"1".equals(s)) {
// 0제거하기
int firstLen = s.length();
s = s.replaceAll("0", "");
int afterLen = s.length();
// 제거한 0의 개수 구하기
int numberOfZero = firstLen - afterLen;
zero += numberOfZero;
// numberOfZero를 이진법으로 변환
s = Integer.toString(afterLen, 2);
++count;
}
answer[0] = count;
answer[1] = zero;
return answer;
}
}
반응형
'알고리즘' 카테고리의 다른 글
[프로그래머스/sql] 131530 가격대 별 상품 개수 구하기 (1) | 2024.11.20 |
---|---|
[프로그래머스/sql] 131529 카테고리 별 상품 개수 구하기 (0) | 2024.11.19 |
[프로그래머스/Java] 12951 JadenCase 문자열 만들기 (0) | 2024.11.16 |
[프로그래머스/sql] 59047 이름에 el이 들어가는 동물 찾기 (2) | 2024.11.15 |
[프로그래머스/Java] 181851 전국 대회 선발 고사 (0) | 2024.11.14 |