2025年蓝桥杯省赛A组抽奖(洛谷P12140):解密转轮背后的算法奥秘
一. 问题分析
题目要求模拟一个三转轮抽奖机系统,根据每次抽奖后三个转轮显示的数字图案组合,计算获得的积分。系统需要考虑多种获奖情况,并按最高积分规则计算。
二. 关键算法设计
转轮位置计算:
使用模运算处理转轮循环特性
每次转动后更新位置:
pos = (pos + x) % n
奖项判断逻辑:
首先检查三个数字是否相同(最高分200)
然后检查是否有两个数字相同(100分)
最后检查数字连续性:
原始顺序连续(200分)
调整顺序后连续(100分)
连续数字判断技巧:
将三个数字排序后检查差值
原始顺序检查是否严格递增
三. 实现细节
数据结构选择:
使用vector存储转轮图案
使用三个变量记录当前位置
转轮循环特性通过模运算自动处理
使用排序简化连续性判断
严格按题目要求的优先级判断奖项
四.完整代码
#include <iostream> #include <vector> #include <algorithm> using namespace std; int main() { int n, m; cin >> n; // 读取三个转轮的图案 vector<int> wheel1(n), wheel2(n), wheel3(n); for(int i=0; i<n;++i) { cin>>wheel1[i]; } for(int i=0; i<n;++i) { cin>>wheel2[i]; } for(int i=0; i<n;++i) { cin>>wheel3[i]; } cin >> m; int pos1 = 0, pos2 = 0, pos3 = 0; // 初始位置 int total = 0; for (int i = 0; i < m; ++i) { int x1, x2, x3; cin >> x1 >> x2 >> x3; // 计算新的位置(考虑循环) pos1 = (pos1 + x1) % n; pos2 = (pos2 + x2) % n; pos3 = (pos3 + x3) % n; // 获取当前三个转轮的数字 int a = wheel1[pos1]; int b = wheel2[pos2]; int c = wheel3[pos3]; // 判断奖项 int score = 0; // 1. 三个相同 if (a == b && b == c) { score = 200; } // 2. 两个相同 else if (a == b || b == c || a == c) { score = 100; } // 3. 三个连续(顺序) else { vector<int> nums = {a, b, c}; sort(nums.begin(), nums.end()); // 检查是否连续 if (nums[1] - nums[0] == 1 && nums[2] - nums[1] == 1) { // 原始顺序连续 if (b - a == 1 && c - b == 1) { score = 200; } // 调整后连续 else { score = 100; } } } total += score; } cout << total << endl; return 0; }
五. 扩展思考
可能的改进方向:
添加更多奖项规则
支持可变数量的转轮
添加图形界面显示
实现历史记录功能
六. 总结
通过这个问题,我们学习了:
原创内容 转载请注明出处