작성일 :

문제 링크

4581번 - Voting

설명

투표 문자열이 주어졌을 때 쿼럼 여부와 찬반 결과를 출력하는 문제입니다.


접근법

한 줄씩 읽다가 #이 나오면 종료합니다.
결석이 전체의 절반 이상이면 즉시 “need quorum”을 출력하고, 아니면 Y와 N의 개수를 비교해 결과를 결정합니다.


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
27
using System;
using System.Text;

class Program {
  static void Main() {
    var sb = new StringBuilder();
    while (true) {
      var line = Console.ReadLine();
      if (line == null || line == "#") break;
      var yes = 0;
      var no = 0;
      var absent = 0;
      foreach (var ch in line) {
        if (ch == 'Y') yes++;
        else if (ch == 'N') no++;
        else if (ch == 'A') absent++;
      }

      if (absent * 2 >= line.Length) sb.AppendLine("need quorum");
      else if (yes > no) sb.AppendLine("yes");
      else if (no > yes) sb.AppendLine("no");
      else sb.AppendLine("tie");
    }

    Console.Write(sb);
  }
}

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
#include <bits/stdc++.h>
using namespace std;

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

  string line;
  while (getline(cin, line)) {
    if (line == "#") break;
    int yes = 0, no = 0, absent = 0;
    for (char ch : line) {
      if (ch == 'Y') yes++;
      else if (ch == 'N') no++;
      else if (ch == 'A') absent++;
    }

    if (absent * 2 >= (int)line.size()) cout << "need quorum\n";
    else if (yes > no) cout << "yes\n";
    else if (no > yes) cout << "no\n";
    else cout << "tie\n";
  }

  return 0;
}