작성일 :

문제 링크

4850번 - Baskets of Gold Coins

설명

각각의 바구니에서 골드 코인을 특정 개수만큼 꺼내어 그 무게를 측정하여, 가장 가벼운 코인이 들어있는 바구니를 찾는 문제입니다.

문제의 설명에 따르면, 마법사는 1 번 바구니에서 1 개, 2 번 바구니에서 2 개, … , n - 1 번 바구니에서 n - 1 개의 코인을 선택하여 측정합니다.

입력으로는 바구니의 개수 n , 코인의 표준 무게 w , 가장 가벼운 코인과의 무게 차이 d , 그리고 마법사가 측정한 코인들의 총 무게 가 주어집니다.

이 때, 코인이 모두 표준 무게였을 때의 총 무게에서 마법사가 측정한 코인들의 총 무게를 빼고, 그 차이를 d 로 나누면 가장 가벼운 코인이 들어있는 바구니의 번호를 알 수 있습니다.

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
namespace Solution {
  class Program {
    static void Main(string[] args) {

      while (true) {
        var input = Console.ReadLine()?.Split(' ');
        if (input == null) break ;

        var n = int.Parse(input[0]);
        var w = int.Parse(input[1]);
        var d = int.Parse(input[2]);
        var totalWeight = int.Parse(input[3]);

        var standardWeight = w * ((n - 1) * n) / 2;
        var numBasket = (standardWeight - totalWeight) / d;

        if (numBasket == 0) Console.WriteLine(n);
        else Console.WriteLine(numBasket);
      }

    }
  }
}



[ C++ ]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <bits/stdc++.h>

using namespace std;

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

  while (true) {
    int n, w, d, totalWeight;
    cin >> n >> w >> d >> totalWeight;
    if (cin.eof()) break ;

    int standardWeight = w * ((n - 1) * n) / 2;
    int numBasket = (standardWeight - totalWeight) / d;

    if (numBasket == 0) cout << n << "\n";
    else cout << numBasket << "\n";
  }

  return 0;
}