对于目前糖果数分为两种情况 1.是偶数,直接选择分配,也就是ans=dfs(n>>1) 2.是奇数但不是1则考虑+1和-1操作再分配ans=max(dfs((n+1)>>1),(n-1)>>1,ans) 3.是1直接反回ans 考虑dfs递归出所有情况最小值即可
小红从糖果盒中随意抓一把糖果,每次小红会取出一半的糖果分给同学们。
当糖果不能平均分配时,小红可以选择从糖果盒中(假设盒中糖果足够)取出一个糖果或放回一个糖果。
小红最少需要多少次(取出、放回和平均分配均记一次),能将手中糖果分至只剩一颗。
抓取的糖果数<1000000000
最少分至一颗糖果的次数
输入
15
输出
5
15+1=16;
16/2=8;
8/2=4;
4/2=2;
2/2=1;