丢石头--c程序--递归法

题目:小强同学背着一筐数量为N的石头(一样)。每走一步可以从以下方案中选择一种,

方案1、如果当前框里石头为2的倍数,那么可以丢掉其中1/2;

方案2、如果当前框里石头为3的倍数,那么可以丢掉其中2/3;

方案3、如果当前框里的石头不是2或者3的倍数,那么只能丢一块石头;

请问小强最少走多少步,才可以把石头全丢掉。

说明:不是简单的优先级判断,首选2,1,3。比如10块石头,手中剩余石头数10---9----3-----1-----0,只要4步。

C程序:

/* 函数功能:丢弃石头的最小步数 
 * 函数参数:有n个石头
 * 函数返回值:最小步数 
 */

int Step_Stones(int n)
{
         if(n == 0)return 0;
         if(n % 3 == 0 && n % 2 == 0){
                  return (Step_Stones(n / 3) > Step_Stones(n / 2) ? Step_Stones(n / 2) : Step_Stones(n / 3)) + 1;
         }
         else if(n % 3 == 0 && n % 2) {
                  return (Step_Stones(n / 3) > Step_Stones(n - 1) ? Step_Stones(n - 1) : Step_Stones(n / 3)) + 1;
         }else if(n % 3 && n % 2 == 0){
                  return (Step_Stones(n / 2) > Step_Stones(n - 1) ? Step_Stones(n - 1) : Step_Stones(n / 2)) + 1;
         }else if(n % 3 && n % 2){
                  return Step_Stones(n - 1) + 1;
         }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值