[USACO08OCT] Bovine Bones G
题目描述
Bessie 喜欢桌游和角色扮演游戏,所以她说服了 Farmer John 驾车送她去爱好商店,在那里她购买了三个用于掷骰子的骰子。这些公平的骰子分别有 $S_1$、$S_2$ 和 $S_3$ 个面(2≤S 1≤20;2≤S 2≤20;2≤S 3≤40),上面分别包含 $1$ 到 $S_1$,$S_2$ 和 $S_3$ 之间的所有整数。Bessie 不断地掷骰子,试图找出哪个三个骰子的点数和出现得最频繁。如果有多个和出现得最频繁,输出其中最小的和。
输入格式
第 1 行:三个用空格分隔的整数:$S_1$、$S_2$ 和 $S_3$。
输出格式
第 1 行:当骰子以每种可能的组合掷出时,出现次数最多的最小整数和。
输入输出样例 #1
输入 #1
3 2 3
输出 #1
5
说明/提示
这里是所有可能的结果。
1 1 1 -> 3
1 2 1 -> 4
2 1 1 -> 4
2 2 1 -> 5
3 1 1 -> 5
3 2 1 -> 6
1 1 2 -> 4
1 2 2 -> 5
2 1 2 -> 5
2 2 2 -> 6
3 1 2 -> 6
3 2 2 -> 7
1 1 3 -> 5
1 2 3 -> 6
2 1 3 -> 6
2 2 3 -> 7
3 1 3 -> 7
3 2 3 -> 8
5 和 6 都出现得最频繁(各五次),所以答案是 5。
题面翻译由 ChatGPT-4o 提供。
答案
#include <bits/stdc++.h>
using namespace std;
int f[110],ans,cnt,s1,s2,s3;
int main(){
cin>>s1>>s2>>s3;
for(int i=1;i<=s1;i++){
for(int j=1;j<=s2;j++){
for(int k=1;k<=s3;k++){
int sum=i+j+k;
f[sum]++;
}
}
}
for(int sum=3;sum<=s1+s2+s3;sum++){
if(f[sum]>cnt){
cnt=f[sum];
ans=sum;
}
}
cout<<ans;
return 0;
}
过程
由数据范围 2≤S 1≤20;2≤S 2≤20;2≤S 3≤40 很快便想到暴力枚举,对于相加的结果用一个桶数组累加次数。
由数据范围得知累加和最多为 20+20+40=80,故桶数组 t 开到 80+5=85。
桶数组 t、最多次数 num 需要初始化为 0 或使其变为全局变量以实现全部初始化为 0。