인프런 커뮤니티 질문&답변
퀴즈
대소문자를 구분하지 않고 문자열 내 특정 문자의 총 개수를 세려면, 어떤 방법이 가장 효율적일까요?
문자열을 반복하며 각 문자가 찾으려는 문자의 대문자 또는 소문자인지 모두 비교한다.
문자열 전체를 한 가지 케이스(예: 모두 대문자)로 통일한 후 해당 문자의 개수를 센다.
대문자와 소문자의 개수를 각각 세어 합산한다.
Set 자료구조를 사용하여 중복 없이 문자를 저장한 후 개수를 센다.
답변 2
0
안녕하세요! 결과 출력 하실 때
for (char c : T.solution(str).toCharArray()) {
System.out.print(c + " ");
}
이 부분에서 띄어쓰기 " " 넣으셔서 띄어쓰기 출력됩니다.
0
package main;
import java.util.Scanner;
public class Main {
public String solution(String str) {
String answer = "";
str = str + " ";
int cnt = 1;
for (int i = 0; i < str.length() - 1; i++) {
if(str.charAt(i) == str.charAt(i+1)) cnt++;
else {
answer += str.charAt(i);
if(cnt > 1) {
answer += cnt;
cnt = 1;
}
}
}
return answer;
}
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
String str = scan.next();
Main T = new Main();
for (char c : T.solution(str).toCharArray()) {
System.out.print(c + " ");
}
}
}





