結果
| 問題 | No.662 スロットマシーン |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2018-06-03 13:07:29 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0 + boost 1.89.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,422 bytes |
| 記録 | |
| コンパイル時間 | 960 ms |
| コンパイル使用メモリ | 75,988 KB |
| 実行使用メモリ | 10,752 KB |
| 最終ジャッジ日時 | 2024-06-30 09:19:16 |
| 合計ジャッジ時間 | 4,890 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 6 TLE * 1 -- * 12 |
ソースコード
#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;
}