打靶问题java递归_打靶射击[递归]

一个射击运动员打靶,靶一共有10环,连开10枪打中90环的可能行有多少种?

long compute(int score, int num)

{

if (score<0||score>num*10) return 0; //如果剩余还需的分数score<0,说明超过了90分,如果score>num*10,说明剩余的num次无法满足目标环数

if ((num==1&&score<10)||(score==num*10)) return 1; //如果为最后一次射击,而且剩余分数score<10,则还有一种可能;如果剩余分数score刚好等于剩余次数num*10,也就只剩一种可能性

long count = 0;

for (int i = 0; i<=10; i++)

{

count +=compute(score-i,num-1);//当第num次射击射中i环,还剩score-i环,以及num-1次射击机会

}

return count;

}

设f()=0,是一次失败的组合,f()=1是一次成功的组合f(n,sum),n:轮次,sum:本轮及本轮之后应打中的总环数f(1,sum),sum<0||sum>10,则返回0;                sum<=10,这说明最后一枪只要打中sum环,就能满足题设,返回1,即一次组合情况f(2,sum),sum<0||sum>20,则返回0;                sum==20,这说明最后两枪只要打都中10环,就能满足题设,返回1                sum<20,如果倒数第二枪打中x环[0,10],最后一枪打中sum-x环,也就能满足题设,返回1注意这里,上一句就可以描述为当本轮打中x环的情况下,剩下的几轮能打中sum-x环会用多少种情况,也即f(n-1,sum-x)种情况

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值