結果
| 問題 | No.662 スロットマシーン |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2018-06-03 13:07:29 |
| 言語 | C++11 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,422 bytes |
| 記録 | |
| コンパイル時間 | 2,201 ms |
| コンパイル使用メモリ | 97,812 KB |
| 実行使用メモリ | 12,800 KB |
| 最終ジャッジ日時 | 2026-03-20 05:37:57 |
| 合計ジャッジ時間 | 38,756 ms |
|
ジャッジサーバーID (参考情報) |
judge2_0 / judge1_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 8 TLE * 11 |
ソースコード
#include <iostream>
#include <vector>
#include <array>
#include <map>
#include <string>
using namespace std;
const int N = 5;
int main() {
array<int, N> cs, bs{};
vector<int> rs[3];
map<string, int> m;
for (int i = 0; i < N; i++) {
string s;
cin >> s >> cs[i];
m[s] = i;
}
for (int i = 0; i < 3; i++) {
int n;
cin >> n;
for (int j = 0; j < n; j++) {
string s;
cin >> s;
rs[i].emplace_back(m[s]);
}
}
for (int i = 0; i < 3; i++) {
rs[i].emplace_back(rs[i][0]);
rs[i].emplace_back(rs[i][1]);
}
for (int i = 0; i < rs[0].size()-2; i++) {
for (int j = 0; j < rs[1].size()-2; j++) {
for (int k = 0; k < rs[2].size()-2; k++) {
if (rs[0][i] == rs[1][j] && rs[1][j] == rs[2][k]) {
bs[rs[0][i]]++;
}
if (rs[0][i + 1] == rs[1][j + 1] && rs[1][j + 1] == rs[2][k + 1]) {
bs[rs[0][i+1]]++;
}
if (rs[0][i + 2] == rs[1][j + 2] && rs[1][j + 2] == rs[2][k + 2]) {
bs[rs[0][i+2]]++;
}
if (rs[0][i] == rs[1][j + 1] && rs[1][j + 1] == rs[2][k + 2]) {
bs[rs[0][i]]++;
}
if (rs[0][i + 2] == rs[1][j + 1] && rs[1][j + 1] == rs[2][k]){
bs[rs[0][i+2]]++;
}
}
}
}
double a = rs[0].size() - 2;
double b = rs[1].size() - 2;
double c = rs[2].size() - 2;
double exp=0;
for (int i = 0; i < N; i++) {
exp += cs[i] / a * bs[i] / b;
}
exp /= c;
cout << exp << endl;
for (int i : bs) {
cout << i << endl;
}
return 0;
}