728x90
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
32
33
34
|
class Solution {
public int solution(String s) {
int answer = s.length();
// s.length()/2까지만 하면 됨
for(int i=1; i<=s.length()/2; i++){
String preUnit = "";
int accumNum = 1;
int compressedNum = s.length();
for(int j=0; j+i<=s.length(); j+=i){
// System.out.print(j+" ");
String currUnit = s.substring(j,j+i);
if(currUnit.equals(preUnit)){
accumNum++;
compressedNum-=i;
}
else{
if(accumNum>1)
compressedNum+=(Math.log10(accumNum)+1);
accumNum = 1;
preUnit = currUnit;
}
}
if(accumNum>1)
compressedNum+=(Math.log10(accumNum)+1);
// System.out.println(i+" "+compressedNum);
answer = Math.min(answer, compressedNum);
}
return answer;
}
}
|
cs |
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
import java.util.*;
class Solution {
public int solution(String s) {
int answer = s.length();
// ex) abc abc (idx1:0 idx2:3 idx3:3 idx4:6)
int startIdx = 0, unit = 1;
while(unit<=s.length()/2){
// int[] idx = makeIdxArr(startIdx, unit);
// for(int i : idx)
// System.out.println(i);
startIdx = 0;
int accumNum = 1;
String preStr = "";
int answerCandi = s.length();
// System.out.println((int)( Math.log10(10)+1 ));
while(true){
if(startIdx+unit>s.length()){
if(accumNum>1)
answerCandi+=(int)(Math.log10(accumNum)+1);
accumNum = 1;
answer = Math.min(answer, answerCandi);
break;
}
String currStr = s.substring(startIdx, startIdx+unit);
if(currStr.equals(preStr)){
accumNum++;
answerCandi -= currStr.length();
}
else{
/**
중복된 문자들 누적된 숫자 처리
**/
if(accumNum>1)
answerCandi+=(int)(Math.log10(accumNum)+1);
accumNum = 1;
}
preStr = currStr;
startIdx+=unit;
// break;
}
unit++;
}
return answer;
}
// public int[] makeIdxArr(int startIdx, int unit){
// int[] ret = new int[4];
// ret[0] = startIdx;
// ret[1] = startIdx+unit;
// ret[2] = ret[1];
// ret[3] = ret[2]+unit;
// return ret;
// }
}
|
cs |
'알고리즘 풀이 > 프로그래머스' 카테고리의 다른 글
2 ★ [프로그래머스][JAVA] 124 나라의 숫자 (수학) (0) | 2022.02.27 |
---|---|
[프로그래머스][JAVA] 멀쩡한 사각형 (수학) (0) | 2022.02.27 |
[프로그래머스][JAVA] 신고 결과 받기 (시뮬레이션) (0) | 2022.02.23 |
[프로그래머스][JAVA] [1차] 비밀지도 (문자열) (0) | 2022.02.06 |
[프로그래머스][JAVA] 문자열 내 마음대로 정렬하기 (문자열) (0) | 2022.02.05 |