【GESP】C++一级练习BCQM3048,顺序执行、逆推运算
一道根据结果,一步一步逆推之前结果的题,完全顺序语句执行。
BCQM3048
题目要求
描述
甲、乙、丙三人共有x元钱,先由甲分钱给乙、丙两人,所分给的数与各人已有数相同;接着由乙分给甲、丙,分法同前;再由丙分钱给甲、乙,分法亦同前。经上述三次分钱之后,每个人的钱数恰好一样多。 求原先各人的钱数分别是多少?
输入
三个人的总钱数。(0≤x≤109)
输出
甲乙丙三人原有的钱数,用空格隔开。
输入样例
24
输出样例
13 7 4
题目分析
这道题目需要我们从最终状态逆推回初始状态:
最终状态:三人钱数相等,每人拥有总钱数的三分之一,即 x/3。
逆推第三次分钱(丙分钱给甲、乙):
- 甲和乙的钱数是现在的一半
- 丙分钱前的钱数是现在的 + 现甲 + 现乙
- 逆推第二次分钱(乙分钱给甲、丙):
- 甲和丙的钱数是现在的一半
- 乙分钱前的钱数是现在的 + 现甲 + 现丙
- 逆推第一次分钱(甲分钱给乙、丙):
- 乙和丙的钱数是现在的一半
- 甲分钱前的钱数是现在的 + 现乙 + 现丙
通过这种逆推方法,我们可以得到初始状态下甲、乙、丙三人的钱数。
代码参考
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
using namespace std;
int main() {
int x;
cin >> x;
int avg;
avg = x / 3;
int first, second, third;
first = avg / 2;
second = avg / 2;
third = avg + first + second;
first = first / 2;
third = third / 2;
second = second + first + third;
second = second / 2;
third = third / 2;
first = first + second + third;
cout << first << " " << second << " " << third;
return 0;
}
所有代码已上传至Github:https://github.com/lihongzheshuai/yummy-code
本文由作者按照 CC BY 4.0 进行授权