Gym - 101408H Matchsticks

这篇博客探讨了如何使用n根火柴棒构建最大的和最小的数字,无前导零。最大数的构造相对直观,而最小数的构建则需要更复杂的策略。当n为7的倍数时,全摆成'8'是最优解,否则需要通过拆分和组合寻找最小位数。博主提供了详细思路,包括如何处理火柴棒剩余的情况,并建议通过代码实现来更好地理解该问题。
摘要由CSDN通过智能技术生成

https://oomake.com/question/1736140点击查看更多大佬

题意:

n根火柴,能摆出的最大数和最小数,没有前导零。

思路:

最大数很简单,n是偶数就“111”,是奇数就"711",位数尽可能大。

最小数位数要尽可能小,如果n是7的倍数,全摆成‘8’是最优的;如果不是,那我们要让当前摆的值尽可能小,这句话不好理解,一般你看懂代码才能明白,接下来我会用更简单的思路来让你理解这种解法。

思路详解:

假如我们有n根火柴,要摆出最小的数,我们会先摆‘8’,消耗尽可能多的火柴,会出现多{0,1,2,3,4,5,6}根火柴的情况,多0已经是最优解,不必理会;多1,我们拆‘8’,n>=2不会出现给你1根的情况,我们一定有‘8’拆,把‘8’拆成‘0’,组合成‘10’是最优的;多2,最优解‘18’;多

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值