过年了,刘备、关羽、张飞一起放鞭炮,每一个人一支香,每人初始都为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;
}
选取一个数组,既然是鞭炮,那么只有两种形态,故而可以使用数组将其包含,最后计算被更改了的数量。