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
- 자바
- 자바 순열 코드
- 알고리즘
- 상속
- inner class
- 자바 재귀 조합
- jquery 속성선택자
- 자바스크립트 이벤트처리
- char to str
- java Collections.sort()
- 서로소
- 순열 재귀
- parseInt()
- java 내부 클래스
- 순열코드
- 후위표기
- 재귀함수
- str to char array
- 조합 재귀
- java lambda
- jquery 필터선택자
- 자바입출력
- 알고리즘 그래프
- 자바스크립트 이벤트중지
- 재귀
- Interface
- jquery dom 계층 선택자
- 자바 조합 재귀
- jquery 이벤트 처리
- Java
Archives
- Today
- Total
유블로그
[프로그래머스] 큰 수 만들기 본문
프로그래머스 level 2 큰 수 만들기
제거할 인덱스를 k개 고르는 조합(재귀) 코드를 사용했는데 시간초과 때문에 처음부터 다시 짰다.
StringBuilder를 사용했고,
현재 내 위치와 나의 바로 다음 위치의 숫자 크기를 비교하여 내가 더 작으면 나를 StringBuilder 에서 지우고 다시 그 위치부터 나의 다음 위치와 비교하는 방식이다.
그렇게 k개의 숫자를 제거하게 되면 끝냈다.
이렇게 간단한 코드를 생각을 못해서 약 3시간? 혹은 좀 더 ? 걸렸던 듯..
class Solution {
public String solution(String number, int k) {
StringBuilder sb = new StringBuilder(number);
int N = number.length();
int cur = 0;
while(true) {
if(k <= 0) break;
if(cur == N-1) {
return sb.substring(0, N-k);
}
if(sb.charAt(cur)-'0' < sb.charAt(cur+1)-'0') {
sb.delete(cur, cur+1);
N--;
k--;
if(--cur < 0) cur = 0;
}
else cur++;
}
return sb.toString();
}
}
'알고리즘' 카테고리의 다른 글
[프로그래머스] 섬 연결하기 (0) | 2020.12.14 |
---|---|
[프로그래머스] 구명보트 (0) | 2020.12.14 |
[프로그래머스] 조이스틱 (0) | 2020.12.14 |
[알고리즘] Next Permutation : 순열 시간 줄이기 (0) | 2020.10.04 |
[컴퓨팅사고력] 알고리즘에 필요하거나 도움될 수 있는 것들 (0) | 2020.10.04 |