BOJ 코딩테스트/Bronze
BOJ 1264번 : 모음의 개수 (C++/Python/Bronze 4)
dev스카이
2022. 8. 22. 22:47
1264번: 모음의 개수
입력은 여러 개의 테스트 케이스로 이루어져 있으며, 각 줄마다 영어 대소문자, ',', '.', '!', '?', 공백으로 이루어진 문장이 주어진다. 각 줄은 최대 255글자로 이루어져 있다. 입력의 끝에는 한 줄
www.acmicpc.net
문제
영문 문장을 입력받아 모음의 개수를 세는 프로그램을 작성하시오. 모음은 'a', 'e', 'i', 'o', 'u'이며 대문자 또는 소문자이다.
입력
입력은 여러 개의 테스트 케이스로 이루어져 있으며, 각 줄마다 영어 대소문자, ',', '.', '!', '?', 공백으로 이루어진 문장이 주어진다. 각 줄은 최대 255글자로 이루어져 있다. 입력의 끝에는 한 줄에 '#' 한 글자만이 주어진다.
출력
각 줄마다 모음의 개수를 세서 출력한다.
예제 입력
How are you today?
Quite well, thank you, how about yourself?
I live at number twenty four.
#
예제 출력
7
14
9
Solution
C++
#include <iostream>
#include <string>
using namespace std;
int main() {
string s;
while(1){
int cnt = 0;
getline(cin, s);
for(int i=0; i<s.length(); i++){
s[i] = tolower(s[i]); //전체 소문자로 변환
if(s[i] == 'a' || s[i] == 'e' || s[i] == 'i' || s[i] == 'o' || s[i] == 'u')
cnt++;
}
if(s == "#") break;
cout << cnt << '\n';
}
return 0;
}
Python
while 1:
n = input()
if n == '#': break;
cnt = 0
n = n.lower()
for char in n:
if char in ('a', 'e', 'i', 'o', 'u'):
cnt = cnt + 1
print(cnt)