PS(Java)/인프런 강의 문제

[PS] 인프런 강의 - 문자열 11. 문자열 압축

UL :) 2022. 10. 14. 02:15

 

문제

문자 바로 오른쪽에 반복 횟수를 표기하는 방법으로 문자열을 압축하는 프로그램을 작성하시오. 단 반복횟수가 1인 경우 생략합니다.

 

▣ 입력설명
첫 줄에 문자열이 주어진다. 문자열의 길이는 100을 넘지 않는다.

 

▣ 출력설명
첫 줄에 압축된 문자열을 출력한다.

 

▣ 입력예제 1
KKHSSSSSSSE

 

▣ 출력예제 1
K2HS7E

 

풀이

 

간단한 문제지만 for문에서 i번째 문자와 이전 문자(i-1번째 문자)가 다르면, 이전 문자와 반복횟수를 출력하는 로직으로 짰기 때문에, 마지막 문자의 경우 출력되지 않는 문제가 생기니 반드시 문자열에 공백문자를 하나 추가해둬야한다.

 

코드

1) 내가 푼 방식

import java.util.Scanner;

public class Main {
 
	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);

		String s = in.next() + " "; //주의! 반드시 공백을 붙여줘야한다
		String answer="";
		char c = s.charAt(0);
		int sum = 1;
		
		for(int i=1; i<s.length(); i++) {
			char tmp = s.charAt(i);
			if(tmp == c) sum++;
			else {
				answer += c;
				if(sum > 1) answer += sum;
				sum = 1;
				c = tmp;
			}
		}
		
		System.out.print(answer);
		
	}
}