CS/Data Structure & Algorithm

[String] 1. 문자 찾기

문제

설명

한 개의 문자열을 입력받고, 특정 문자를 입력받아 해당 특정문자가 입력받은 문자열에 몇 개 존재하는지 알아내는 프로그램을 작성하세요.

대소문자를 구분하지 않습니다.문자열의 길이는 100을 넘지 않습니다.

입력

첫 줄에 문자열이 주어지고, 두 번째 줄에 문자가 주어진다.

문자열은 영어 알파벳으로만 구성되어 있습니다.

출력

첫 줄에 해당 문자의 개수를 출력한다.

예시 입력 1 

Computercooler
c

예시 출력 1

2

 

풀이

1. 문자열과 특정 문자를 받아옵니다.

2. 받아온 문자열을 소문자나 대문자로 변경합니다.

3. 문자열 첫번째부터 특정 문자와 한개씩 비교합니다. 똑같은 것이 있을 경우 answer 변수에 +1 합니다.

4. 최종 answer를 출력합니다.

 

배경지식

자바 String 클래스의 동작 방식과 지원하는 여러 메서드들의 사용 방법을 알고 있어야 합니다.

자바 입출력 Scanner 클래스를 사용할 줄 알아야 합니다.

향상된 for문을 사용할 줄 알면 좋습니다.

 

정답

import java.util.*;
class Main {
    public int solution(String str, char t) {
        int answer = 0;
        str = str.toUpperCase();
        t = Character.toUpperCase(t);
        for(char c : str.toCharArray()) {
            if (c == t) answer++;
        }
        return answer;
    }

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

        // 입력 받는 과정
        String str = in.next();
        char c = in.next().charAt(0);

        // 알고리즘 풀이 및 출력
        System.out.print(T.solution(str, c));
    }
}

'CS > Data Structure & Algorithm' 카테고리의 다른 글

자료구조와 알고리즘을 공부하는 이유  (0) 2022.08.13
[String] 2. 대소문자 변환  (0) 2022.08.10
List  (0) 2021.12.02
deque  (0) 2021.12.02
Queue  (0) 2021.11.25