码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 第一季:5递归与迭代【Java面试题】


    第一季:5递归与迭代【Java面试题】

    • 前言
    • 推荐
    • 第一季:5递归与迭代
      • 题目
      • 递归
      • 循环迭代
      • 小结
    • 最后

    前言


    2022 9/30 12:36

    路漫漫其修远兮,吾将上下而求索


    本文是根据尚硅谷学习所做笔记

    仅供学习交流使用,转载注明出处


    推荐

    【尚硅谷经典Java面试题第一季(java面试精讲)-哔哩哔哩】

    第一季:5递归与迭代

    题目

    编程题:
    有 n 步台阶,一次只能上 1 步或者 2 步,共有多少种走法?

    1.递归
    2.循环迭代

    递归

    斐波那契数列
    0227

    package fbnq5;
    
    import org.junit.Test;
    
    public class TestStep {
        @Test
        public void test() {
            long start=System.currentTimeMillis();
            System.out.println(f(40));//165580141
            long end=System.currentTimeMillis();
            System.out.println(end-start);//335
        }
    
        //实现f(n):求n步台阶,一个有几种走法
        public  int f(int n){
            if (n<1){
                throw new IllegalArgumentException(n+"不能小于1");
            }
            if (n==1||n==2){
                return n;
            }
            return f(n-2)+f(n-1);
        }
    
    }
    
    

    循环迭代

    1141

    package fbnq5;
    
    import org.junit.Test;
    
    public class TestStep {
        @Test
        public void test() {
            long start=System.currentTimeMillis();
            System.out.println(f(40));//165580141
            long end=System.currentTimeMillis();
            System.out.println(end-start);//335
        }
    
        //实现f(n):求n步台阶,一个有几种走法
        public  int f(int n){
            if (n<1){
                throw new IllegalArgumentException(n+"不能小于1");
            }
            if (n==1||n==2){
                return n;
            }
            return f(n-2)+f(n-1);
        }
    
    }
    
    

    小结

    • 方法调用自身称为递归,利用变量的原值推出新值称为迭代。

    • 递归

      • 优点:大问题转为小问题,可以减少代码量,同时代码精简,可读性好;
      • 缺点:递归调用浪费了空间,而且递归太深容易造成堆栈的溢出。
    • 迭代

      • 优点:代码运行效率好,因为时间复杂度为0(n),而且没有额外空间的开销;
      • 缺点:代码不如递归简洁,可读性好

    最后


    2022 9/30 13:11


    p5


    Markdown 1251 字数 121 行数 当
    HTML 1053 字数 69 段落


  • 相关阅读:
    2022年软件测试面试题大全【含答案】
    ubuntu在线直接升级
    RT-Thread任务间同步及通信
    rocketMQ简单理解
    长难句分析
    【微服务】五. Nacos服务注册
    sql语句中limit、offset的用法
    PHY驱动开发算法详解
    Elasticsearch搜索分析引擎本地部署与远程访问
    基于springboot的暖暖午托管理系统
  • 原文地址:https://blog.csdn.net/qq_51625007/article/details/127121630
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号