문제 풀이/인프런
[JAVA11/알고리즘] 1-1 문자 찾기
윤진노
2022. 7. 28. 18:55
설명
한 개의 문자열을 입력받고, 특정 문자를 입력받아 해당 특정문자가 입력받은 문자열에 몇 개 존재하는지 알아내는 프로그램을 작성하세요.
대소문자를 구분하지 않습니다.문자열의 길이는 100을 넘지 않습니다.
입력
첫 줄에 문자열이 주어지고, 두 번째 줄에 문자가 주어진다.
문자열은 영어 알파벳으로만 구성되어 있습니다.
출력
첫 줄에 해당 문자의 개수를 출력한다.
예시 입력 1
Computercooler
c
예시 출력 1
2
해결
위 문제에서 대소문자를 구분하지 않는다 하였으므로 입력받은 문자열과 문자를 모두 toLowerCase를 사용하여 소문자로 변환한 뒤 비교하였다.
toLowerCase() : 대문자 -> 소문자toLowerCase(): 소문자 -> 대문자
그다음 변환된 문자열과 문자를 반복문을 통해서 비교한뒤 count라는 변수의 값을 return 하였다.
CODE
public class Main {
public static int solution(String str, char c){
int count = 0;
str = str.toLowerCase();
c = Character.toLowerCase(c);
for(int num =0; num<str.length(); num++){
if(c == str.charAt(num))
count++;
}
return count;
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String str = in.next();
char c = in.next().charAt(0);
System.out.println(solution(str,c));
}
}
결과
밑에 틀렸던 이유는 첫번째 줄에 입력받은 문자열은 소문자로 변환하였지만 두번째 줄에 입력받은 문자를 소문자로 변환하지 않아서 생긴 예외 때문이다.