三人分糖果c语言,C语言顺序结构 -C语言桐桐分糖果问题(附带源码)

本文通过一个有趣的数学故事介绍了如何利用倒推法解决关于糖果分配的问题。桐桐在三天内逐步分享糖果,最后剩下与她年龄相同的糖果数,通过这个过程推算出妈妈最初给了桐桐多少颗糖果。文章提供了详细的解题思路、算法描述及C语言程序实现,并展示了运行结果。
摘要由CSDN通过智能技术生成

妈妈给了桐桐一盒糖果,第一天桐桐分糖果的一半给弟弟,自己吃了 5 颗;第二天有好朋友悦悦来家里玩,桐桐又把剩下的糖果分一半给悦悦,自己吃了 4 颗;第三天桐桐吃了剩下的糖果的一半还多 1 颗后,数了数发现她剩下的糖果数量刚好是她今年的岁数。你能算出妈妈一共给了桐桐多少颗糖果吗?

问题分析

输入:输入一个整数表示桐桐年龄,即第三天吃完糖果后剩余的糖果数。

输出:一个整数,表示妈妈给桐桐的糖果总数。

这是一个非常有趣的数学计算题,我们可以使用倒推法来解决。图 1a 表示第三天吃糖果的情况。假如第三天吃糖果之前桐桐手里的糖果数为 x3,吃完糖果后剩余的糖果数是 n,则:

7e2041cfe5a9c6052f66fe0b3526ba4a.gif

因此第三天吃糖果之前桐桐手里的糖果数为x3= ( n + 1 ) * 2。

303e5d43a07634d61a42b721b90060b6.gif

图 1:桐桐吃糖果的情况示意图

x3即为第二天分完、吃完糖果后剩余的糖果数。图 1b 表示第二天吃糖果的情况。若第二天开始时的糖果数为 x2,则:,因此第二天开始时的糖果数为x2= ( x3+ 4 ) * 2。

以此类推,第一天开始时妈妈给桐桐的糖果总数为x1= ( x2+ 5 ) * 2。

算法描述

1) 定义变量 x1、x2、x3 分别表示第 1 天、第 2 天和第 3 天的糖果数、n 表示桐桐的年龄;

2) 用 scanf( ) 输入 n 的值;

3) 计算 x3 的值;

4) 计算 x2 的值;

5) 计算 x1 的值;

6) 用 printf( ) 输出 x1 的值。

代码清单 1:C语言程序源代码(桐桐分糖果)

#include

#include

int main( )

{

system("color 70");

int x1,x2,x3,n;

printf("请输入桐桐的年龄(整数):");

scanf("%d",&n);

x3 = ( n + 1 ) * 2;

x2 = ( x3 + 4 ) * 2;

x1 = ( x2 + 5 ) * 2;

printf("\n妈妈给了%d岁的桐桐%d颗糖果!",n,x1);

system("pause");

return 0;

}

运行结果如下图所示:

请输入桐桐的年龄(整数):8

妈妈给了8岁的桐桐98颗糖果!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值