작성일 :

문제 링크

26350번 - Good Coin Denomination

설명

단순한 구현 문제입니다.

문제의 목표는 입력으로 주어지는 동전들에 대하여, 이전 동전이 그 다음 동전의 2 배 미만인지, 아닌지를 판별하는 것입니다.

판별이 완료되면, 문제의 출력 조건에 맞추어 적절히 출력합니다.


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
28
29
30
31
32
33
34
35
36
namespace Solution {
  class Program {
    static void Main(string[] args) {
      var n = int.Parse(Console.ReadLine()!);

      for (var i = 0; i < n; i++) {
        var input = Console.ReadLine()?.Split();
        var d = int.Parse(input![0]);

        var coins = new List<int>();
        for (var j = 0; j < d; j++)
          coins.Add(int.Parse(input![j + 1]));

        Console.Write("Denominations: ");
        for (var j = 0; j < d; j++)
          Console.Write(coins[j] + " ");
        Console.WriteLine();

        var isValid = true;
        var prev = coins[0];
        for (var j = 1; j < d; j++) {
          if (coins[j] < 2 * prev) {
            isValid = false;
            break;
          }
          prev = coins[j];
        }

        if (isValid) Console.WriteLine("Good coin denominations!");
        else Console.WriteLine("Bad coin denominations!");
        if (i != n - 1) Console.WriteLine();
      }

    }
  }
}



[ 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
29
30
31
32
33
34
35
36
37
38
39
#include <bits/stdc++.h>

using namespace std;

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

  int n; cin >> n;

  for (int i = 0; i < n; i++) {
    int d; cin >> d;
    vector<int> coins(d);

    for (int j = 0; j < d; j++)
      cin >> coins[j];

    cout << "Denominations: ";
    for (int j = 0; j < d; j++)
      cout << coins[j] << " ";
    cout << "\n";

    bool isValid = true;
    int prev = coins[0];
    for (int j = 1; j < d; j++) {
      if (coins[j] < 2 * prev) {
        isValid = false;
        break;
      }
      prev = coins[j];
    }

    if (isValid) cout << "Good coin denominations!\n";
    else cout << "Bad coin denominations!\n";
    if (i != n - 1) cout << "\n";
  }

  return 0;
}