작성일 :

문제 링크

14649번 - 문홍안

설명

비서들의 이동이 끝난 뒤 돌의 색깔 개수에 비례해 재산을 분배할 때, 각 색의 분배 금액을 출력하는 문제입니다.


접근법

각 돌 i를 밟는 횟수는 오른쪽으로 이동하는 비서 중 시작 위치가 i보다 작은 사람 수와, 왼쪽으로 이동하는 비서 중 시작 위치가 i보다 큰 사람 수의 합입니다.
밟은 횟수의 3으로 나눈 나머지에 따라 최종 색깔을 결정해 파란색/빨간색/초록색 개수를 센 뒤 P * 개수 / 100을 출력합니다.


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
37
38
39
40
41
42
43
44
using System;
using System.Text;

class Program {
  static void Main() {
    var parts = Console.In.ReadToEnd().Split();
    var idx = 0;
    var p = int.Parse(parts[idx++]);
    var n = int.Parse(parts[idx++]);

    var pos = new int[n];
    var dir = new char[n];
    for (var i = 0; i < n; i++) {
      pos[i] = int.Parse(parts[idx++]);
      dir[i] = parts[idx++][0];
    }

    var blue = 0;
    var red = 0;
    var green = 0;

    for (var i = 1; i <= 100; i++) {
      var steps = 0;
      for (var j = 0; j < n; j++) {
        if (dir[j] == 'R') {
          if (pos[j] < i) steps++;
        } else {
          if (pos[j] > i) steps++;
        }
      }

      var mod = steps % 3;
      if (mod == 0) blue++;
      else if (mod == 1) red++;
      else green++;
    }

    var sb = new StringBuilder();
    sb.AppendLine($"{p * blue / 100.0:F2}");
    sb.AppendLine($"{p * red / 100.0:F2}");
    sb.AppendLine($"{p * green / 100.0:F2}");
    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
26
27
28
29
30
31
32
33
34
35
36
37
#include <bits/stdc++.h>
using namespace std;

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

  int p, n; cin >> p >> n;
  vector<int> pos(n);
  vector<char> dir(n);
  for (int i = 0; i < n; i++)
    cin >> pos[i] >> dir[i];

  int blue = 0, red = 0, green = 0;
  for (int i = 1; i <= 100; i++) {
    int steps = 0;
    for (int j = 0; j < n; j++) {
      if (dir[j] == 'R') {
        if (pos[j] < i) steps++;
      } else {
        if (pos[j] > i) steps++;
      }
    }

    int mod = steps % 3;
    if (mod == 0) blue++;
    else if (mod == 1) red++;
    else green++;
  }

  cout << fixed << setprecision(2);
  cout << p * blue / 100.0 << "\n";
  cout << p * red / 100.0 << "\n";
  cout << p * green / 100.0 << "\n";

  return 0;
}