小学时候的智力题之编程实现

探讨了一个经典的数学问题:使用特定金额购买汽水并利用空瓶换取更多汽水的最优算法。文章介绍了两种解决方法,一种为迭代计算空瓶换汽水的过程,另一种则通过简化公式直接得出结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如题:喝汽水,1瓶汽水1元,2个空瓶可以换一瓶汽水, 给20元,可以喝多少瓶汽水。

这个题目大家小时候应该都做过吧,暑假寒假作业里面经常出现的,小时候觉得这种题目能做出来的都好厉害的,肯定是经商大佬······
这个题目放现在估计大家都会写,但是不一定喝的完······
编程实现的话也不难,就是除以二,然后累加,最后空瓶只剩一个的时候找老板借一个换汽水喝完了再还回去(怎么感觉白嫖了一瓶?)。编程实现的话也不难,有两种代码:

int DrinkNum(int money) {
	int num = money;
	int empty = num;
	for (; empty / 2 != 0; empty = empty / 2 + empty % 2) {
		num = num + empty / 2;
	}
	return num + empty;
}

第一种是比较中规中矩的做法了,就是不断地喝汽水换空瓶,就算只有一块钱也可以喝两瓶,没钱免谈。
然后是第二种写法

int DrinkNum(int money) {
	return 2 * money;
}

第二种与其说是写法不如说是算法,我只能透露这么多了,剩下的自己想去吧,小学题目别说你······反正我是编出来调试了几个数据之后开始怀疑智商了······

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值