技能树基础——1切面条(两种方法)

一、切面条

一根高筋拉面,中间切一刀,可以得到2根面条。

如果先对折1次,中间切一刀,可以得到3根面条。

如果连续对折2次,中间切一刀,可以得到5根面条。 那么,连续对折10次,中间切一刀,会得到多少面条呢?

1方法(扫描器,数学函数)找出推导式的前提下这样做
推导过程:

这个题应该找有几个节点,这个节点是干扰切断的关键。

这种题一般都会涉及2的次幂。

0折的时候,有0的节点,一刀分为了2条

1折的时候,有1个节点,一刀分为了3条,假如没有那个节点,应该是4条,所以 4 - 1 = 3

2折的时候,是在1折的基础上,本身已经有1个节点,然后再加上2个,1 + 2 = 3个节点,一刀切开本身应该8条,所以8-3=5.

3折的时候,是在2折基础上,1 + 2 + 4 = 7个节点,一刀切开,本身应该16条,16-7=9条。

。。。

。。。

所以我们找出规律:

n折的时候,节点数应该为 2的0次幂+......2的n-1次幂。也就是2的n次幂-1。所以10次的时候,有1024-1=1023个节点。

n折的时候本身应该有2的n+1次幂2048条。所以2048-1023=1025

故而有:

折 条

0 2

1 3

2 5

推导可得:

折 条

0 2

1 3

2 5

n 1+2^n

10 1+2^10=1+2024=1025

推导式:count=1+2^n

转为代码:1+math.pow(2,n)

package 刷题24;

import java.util.Scanner;

public class 基础题 {

    public static void main(String[] args) {
        //        一根高筋拉面,中间切一刀,可以得到2根面条。
        //        如果先对折1次,中间切一刀,可以得到3根面条。
        //        如果连续对折2次,中间切一刀,可以得到5根面条。 那么,连续对折10次,中间切一刀,会得到多少面条呢?
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        sc.close();
        int result=(int)(1+Math.pow(2, n));
        System.out.println(result);
    }
}

2方法(for循环暴力)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
以下是一种可能的解法: ```python n, m = map(int, input().split()) a = list(map(int, input().split())) # 定义一个函数,判断给定的长度是否可以成m段 def check(length): count = 0 for x in a: count += x // length return count >= m # 二分答案,找到最大的长度 left, right = 1, max(a) while left <= right: mid = (left + right) // 2 if check(mid): left = mid + 1 else: right = mid - 1 print(right) ``` 首,读入输入数据。其中,`n`表示初始面条的长度个数,`m`表示要成的段数,`a`是一个长度为`n`的列表,表示每个初始面条的长度。 接下来,我们定义一个函数`check`,用来判断给定的长度是否可以成`m`段。具体实现方式是,遍历所有初始面条的长度,将每个长度除以给定的长度,得到的商之和即为可以成的段数。如果这个段数大于等于`m`,说明给定的长度可以成`m`段(因为我们最终要找到的是最大的满足件的长度,因此这里是大于等于)。 然后,我们使用二分答案来找到最大的长度。具体实现方式是,设定一个左边界`left`和右边界`right`,初始时分别为1和所有初始面条的长度中的最大值。每中间值`mid`,判断是否可以将初始面条成`m`段,如果可以,说明答案在`mid`的右边,因此更新左边界为`mid + 1`;如果不行,说明答案在`mid`的左边,因此更新右边界为`mid - 1`。最终,当`left > right`时,二分结束,最终的答案即为`right`。 最后,输出答案即可。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

W少年没有乌托邦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值