算法题每日一练---第15天:熊怪吃核桃

简介: 森林里有一只熊怪,很爱吃核桃。不过它有个习惯,每次都把找到的核桃分成相等的两份,吃掉一份,留一份。如果不能等分,熊怪就会扔掉一个核桃再分。第二天再继续这个过程,直到最后剩一个核桃了,直接丢掉。

一、问题描述


森林里有一只熊怪,很爱吃核桃。不过它有个习惯,每次都把找到的核桃分成相等的两份,吃掉一份,留一份。如果不能等分,熊怪就会扔掉一个核桃再分。第二天再继续这个过程,直到最后剩一个核桃了,直接丢掉。

有一天,熊怪发现了 1543 个核桃,请问,它在吃这些核桃的过程中,一共要丢掉多少个核桃。


二、题目要求


考察

数学思想,递进条件判断
建议用时5~15min


三、问题分析


这题是一个简单的填空问题,首先总数有1543 这么多个核桃,下面简单分析一下,这个问题的执行步骤具体情况有哪些:

第一天,先丢掉一个,分成两份,每一份771。

第二天,先丢掉一个,分成两份,每一份385。

第三天,先丢掉一个,分成两份,每一份192。

第四天,分成两份,每一份96。

第五天,分成两份,每一份48。

第六天,分成两份,每一份24。

第七天,分成两份,每一份12。

第八天,分成两份,每一份6。

第九天,分成两份,每一份3。

第十天,先丢掉一个,分成两份,每一份1。

直到剩下最后一个直接丢掉,综上所述总共丢掉5个,直到最后剩余一个,总共耗时十天。


四、编码实现


#include <iostream>#include<math.h>usingnamespacestd;
intmain()
{
inti,n=1543,sum=0;//初始化核桃数目和丢掉的核桃数目 while(n)//进入while循环操作     {
if(n%2!=0)//第一步不是偶数,丢掉一个         {
sum++;//丢掉数目++ n--;//总数减一         }
if(n==1)//剩下最后一个,直接丢掉         {
exit(0);//退出循环         }
n=n/2;//数目减半     }
cout<<sum;//输出结果 return0;
}


五、输出结果


输出结果为:5


相关文章
|
6天前
|
算法 Java 程序员
【算法每日一练及解题思路】有n级台阶,一次只能上1级或2级,共有多少种走法?
本文深入解析了“爬楼梯问题”,探讨了递归与迭代两种解法,并提供了Java代码实现。通过分析问题本质,帮助读者理解动态规划技巧,提高解决实际编程问题的能力。关键词:Java, 算法, 动态规划, 爬楼梯问题, 递归, 迭代。
17 0
|
算法
算法题每日一练---第78天:二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target
186 1
算法题每日一练---第78天:二分查找
|
存储 算法
|
算法
算法题每日一练---第76天:丑数 l
丑数 就是只包含质因数 2、3 和 5 的正整数。
146 1
算法题每日一练---第76天:丑数 l
|
算法
算法题每日一练---第75天:Nim 游戏
你和你的朋友,两个人一起玩 Nim 游戏。
320 0
算法题每日一练---第75天:Nim 游戏
|
算法
算法题每日一练---第74天:快乐数
编写一个算法来判断一个数 n 是不是快乐数。
179 0
算法题每日一练---第74天:快乐数
|
存储 算法
算法题每日一练---第73天:加一
给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。
155 0
算法题每日一练---第73天:加一
|
算法
算法题每日一练---第72天:数字 1 的个数
给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数。
224 0
算法题每日一练---第72天:数字 1 的个数
|
存储 算法
算法题每日一练---第71天:回文数
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
151 0
算法题每日一练---第71天:回文数