蓝桥杯历届-比酒量

蓝桥杯历届-比酒量

有一群海盗(不多于20人),在船上比拼酒量。过程如下:打开一瓶酒,所有在场的人平分喝下,有几个人倒下了。再打开一瓶酒平分,又有倒下的,
再次重复...... 

直到开了第4瓶酒,坐着的已经所剩无几,海盗船长也在其中。当第4瓶酒平分喝下后,大家都倒下了。

等船长醒来,发现海盗船搁浅了。他在航海日志中写到:“......昨天,我正好喝了一瓶.......奉劝大家,开船不喝酒,喝酒别开船......”

请你根据这些信息,推断开始有多少人,每一轮喝下来还剩多少人。

如果有多个可能的答案,请列出所有答案,每个答案占一行。

格式是:人数,人数,...

例如,有一种可能是:20,5,4,2,0

答案写在“解答.txt”中,不要写在这里!

分析:根据题目描述,可以分析出题目的需求是要找到4个分数之和等于1,并且这4个分数的分子都是1,需要我们通过编程找到分母。

#include<cstdio>
#include<iostream>
using namespace std;
int d, a1[4];
int d1(int *a1) {
    int sum = a1[0];
    for (int i = 1; i < 4; i++) {
        if (sum % a1[i] != 0) return i;
    }
    return 0;
}
int getS(int *a1) {
    int sum = 0, ss = 1;
    while(d1(a1) != 0) {
        int index = d1(a1);
        a1[0] = a1[0] * a1[index];
        ss = a1[index];
    }
    for (int i = 1; i < 4; i++) {
        sum += (a1[0]/a1[i]);
    }
    return sum+ss;
}
int main() {
    for (int sum = 20; sum >= 1; sum--) {
        for (int a = 1; a <= 20; a++) {
            for (int b = 1; b <= 20; b++) {
                for (int c = 1; c <= 20; c++) {
                    a1[0] = sum, a1[1] = a, a1[2] = b, a1[3] = c;
                    if (getS(a1) == a1[0] && a > b && b > c && sum > a) {
                        printf("%d, %d, %d, %d, 0\n", sum, a, b, c);
                    } 
                }
            }
        }
    }
    return 0;
}

答案是

20,5,4,2,0 
18,9,3,2,0      
15,10,3,2,0      
12,6,4,2,0      

你可能感兴趣的:(蓝桥杯历届-比酒量)