【算法】基础数学思维与技巧(切面条)

1.问题:

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

2.解析:

1)  不对折(对折零次),从中间切一刀          2 = 2
2)  对折一次,从中间切一刀                               3 = 2 + 2^0
3)  对折两次,从中间切一刀                               5 = 2 + 2^0 + 2^1
4)  对折三次,从中间切一刀                               9 = 2 + 2^0 + 2^1 + 2^2

11)  对折十次,从中间切一刀                             ? = 2 + 2^0 + 2^1 + 2^2 + ...... + 2^9 

通过观察这道题的题解思路主要是等差数列   An=2^n+1

在这里主要使用Java函数    Math.pow(double[a],double[b])   输出a的b次方。

3.代码

package Result.DataStructure;

import java.util.Scanner;
/**
 * 切面条
 * @author 晴澜
 * @version 2023.03.17
 */
public class CutNoodles {
    public static void main(String[] args) {
        //创建标准输入流
        Scanner sc=new Scanner(System.in);
        //输入一共切了多少刀
        int knife=sc.nextInt();
        //等差数列:An=2^n+1
        int sum=(int)(Math.pow(2,knife)+1);
        //输出
        System.out.println("面条数量为:"+sum);
    }
}

以上,就是切面条的题解思路以及解法。

长风破浪会有时,直挂云帆济沧海。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值