문제 : boj18409
필요 알고리즘 개념
- 문자열, 구현
- 문자열을 파싱해서 다룰 수 있어야 하는 구현문제이다.
※ 제 코드에서 왜 main 함수에 로직을 직접 작성하지 않았는지, 왜 Scanner를 쓰지 않고 BufferedReader를 사용했는지 등에 대해서는 '자바로 백준 풀 때의 팁 및 주의점' 글을 참고해주세요. 백준을 자바로 풀어보려고 시작하시는 분이나, 백준에서 자바로 풀 때의 팁을 원하시는 분들도 보시는걸 추천드립니다.
풀이
일본어 문제라 못풀 것 같이 생기긴 했는데, 번역기 돌리면 된다. 이 문제의 경우엔 번역기 돌릴 것도 없이 예제 입출력 보면 어떻게 풀지 알수 있다. 뭔가 숫자가 들어오고, 문자가 들어오는데 문자 길이가 숫자와 동일하니 대충 길이라고 생각하면 되고, 그 아래에 _oi_o_e_ 이렇게 써있으니 대충 모음의 수를 세면 되겠구나 생각해볼 수 있다. 그리고 위에 a, i, u, e, o 어쩌구 되있으니 대충 문자열에서 a, i, u, e, o가 나온 횟수를 세면 될 것임을 알 수 있다.
1. a, i, u, e, o가 나오면 세줄 변수 하나를 정한다.
2. 문자열의 각 Character를 확인하면서 해당하는 문자가 나올 경우 '1'의 변수를 증가시켜준다.
코드 : github
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class Main {
private void solution() throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
String s = br.readLine();
int cnt = 0;
for (int i = 0; i < n; i++) {
switch (s.charAt(i)) {
case 'a': case 'i': case 'u': case 'e': case 'o':
cnt++;
}
}
System.out.println(cnt);
}
public static void main(String[] args) throws Exception {
new Main().solution();
}
}
'PS > BOJ' 카테고리의 다른 글
[자바] 백준 25991 - Lots of Liquid (java) (0) | 2022.11.25 |
---|---|
[자바] 백준 3765 - Celebrity jeopardy (java) (0) | 2022.11.25 |
[자바] 백준 10864 - 친구 (java) (0) | 2022.11.25 |
[자바] 백준 2835 - 인기도 조사(java) (0) | 2022.11.16 |
[자바] 백준 1990 - 소수인팰린드롬 (java) (0) | 2022.11.10 |
댓글