经典刘关张放鞭炮问题(c语言)

过年了,刘备、关羽、张飞一起放鞭炮,每一个人一支香,每人初始都为N个鞭炮(散),刘备每一秒燃放一个,关羽每两秒燃放一个,张飞每三秒燃放一个,在不考虑燃烧时间跟安全的情况下,鞭炮即点即炸,开始的时候大家一起开始放鞭炮,问大家都放完时,一共可以听到多少次响声?一共花了多长时间?

本程序需定义函数实现,函数原型为void firecrackers(int n);,编写完成本函数,int n为每个人初始鞭炮个数,函数中需打印鞭炮响声次数与所需时间,没有返回值。鞭炮燃放情况可以参考下面示例(鞭炮数量为3)

时间   刘备   关羽   张飞

1     放     放     放

2     放

3     放     放

4                   放

5            放

6

7                   放

        

#include <stdio.h>

int a[10000];

void firecrackers(int n){
    int time, count;
//    printf("zheshi%d", n);
    count = 0;
    time = 3 * n - 2;
    printf("time = %d\n", time);
    a[0] = 1;
    for(int i = 1; i < n; i++){
        a[i] = 1;
        a[i * 2] = 1;
        a[i * 3] = 1;
    }
    for(int i = 0; i < time; i++){
        if(a[i] == 1){
            count ++;
        }
    }
    printf("count = %d\n", count);

}

int main(void){
    int n;
    printf("请输入初始鞭炮个数:");
    scanf("%d", &n);
    firecrackers(n);
    return 0;
}

选取一个数组,既然是鞭炮,那么只有两种形态,故而可以使用数组将其包含,最后计算被更改了的数量。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值