작성일 :

문제 링크

11319번 - Count Me In

설명

알파벳과 공백으로만 이루어진 여러 문장이 주어집니다.

문장의 개수와 각 문장이 주어질 때, 각 문장의 자음과 모음 개수를 세어 출력하는 문제입니다.

모음은 A, E, I, O, U의 대소문자이며, 나머지 알파벳은 자음입니다.


접근법

모음을 판별하기 위해 모음 집합을 미리 준비합니다.

각 문장을 한 글자씩 순회하며, 알파벳인 경우에만 모음인지 자음인지 확인합니다.


문장 개수를 먼저 읽은 후, 각 문장을 한 줄씩 읽어 처리합니다.

각 문자에 대해 알파벳이 아니면 무시하고, 알파벳이면 모음 집합에 포함되는지 확인하여 모음 또는 자음 개수를 증가시킵니다.

모든 문자를 확인한 후 자음 개수와 모음 개수를 순서대로 출력합니다.



Code

C#

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
using System;
using System.Collections.Generic;

namespace Solution {
  class Program {
    static void Main(string[] args) {
      var s = int.Parse(Console.ReadLine()!);
      var vowels = new HashSet<char>{'A','E','I','O','U','a','e','i','o','u'};

      for (var i = 0; i < s; i++) {
        var line = Console.ReadLine()!;
        var v = 0;
        var c = 0;

        foreach (var ch in line) {
          if (!char.IsLetter(ch)) continue;

          if (vowels.Contains(ch)) v++;
          else c++;
        }

        Console.WriteLine($"{c} {v}");
      }
    }
  }
}

C++

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <bits/stdc++.h>
using namespace std;

int main() {
  ios::sync_with_stdio(false);
  cin.tie(nullptr);

  int s; cin >> s;
  string dummy; getline(cin, dummy);

  string vowels = "AEIOUaeiou";

  for (int i = 0; i < s; i++) {
    string line; getline(cin, line);
    int v = 0, c = 0;

    for (char ch : line) {
      if (!isalpha(static_cast<unsigned char>(ch))) continue;

      if (vowels.find(ch) != string::npos) ++v;
      else ++c;
    }

    cout << c << " " << v << "\n";
  }

  return 0;
}