C语言入门算法——爬楼梯(了解动态规划)

题目描述:

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

示例 1:

输入:n = 2
输出:2
解释:有两种方法可以爬到楼顶。
1. 1 阶 + 1 阶
2. 2 阶

示例 2:

输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
1. 1 阶 + 1 阶 + 1 阶
2. 1 阶 + 2 阶
3. 2 阶 + 1 阶

提示:

  • 1 <= n <= 45

题目来源:爬楼梯

思路及部分代码:

1. 分析

        通过题目我们可以了解到 f(n) 的方法是上一台阶 f(n-1) ——爬一阶台阶到达 f(n)  加上上两阶台阶到达 f(n) 。所以可得 f(n) = f(n - 1) + f(n-2);

2. dynamic() 直接递归(超时

        此函数重复计算,导致时间不够。


int dynamic(int n){if(n == 1) return 1;else if(n == 2) return 2;else{ //大于阶梯数//方法有 f(n) = f(n -1) + f(n - 2);return dynamic(n-1) + dynamic(n-2);}
}

3. dynamic_1(); 从1到n(通过

        通过从1计算到n并保存之前的f(n-1) 和f(n-2)


int dynamic_1(int i, int a1, int a2,int n){if(i == 1){a1 = 0;a2 = 1;}if(i >= n) return a1+a2;else return dynamic_1(i+1, a2, a1+a2,n);
}

4. dynamic_2();  数组 (通过

        在了解动态规划时,看见要用数组,就想到了这样,显示这种和dynamic_1();的方法一样,只是将a1,a2;改成了数组而已。(不是动态规划)


int num[3] = {0,0,0};
int dynamic_2(int i, int n){//更新数据if(i == 1){num[0] = 0;num[1] = 1;num[2] = num[0] + num[1];}else{num[0] = num[1];num[1] = num[2];num[2] = num[0] + num[1];}if(i >= n) return num[2];else return dynamic_2(i+1,n);
}

5. dynamic_3();  动态规划 (通过

        动态规划算法:(百度)核心思想是将问题分解为若干个子问题,并保存这些子问题的解,以便在解决原始问题时可以重复使用,避免重复计算,从而提高算法的效率。动态规划特别适用于那些具有“最优子结构和重叠子问题”特性的问题,在动态规划中,原问题被分解为相对简单的子问题,这些子问题按顺序求解,并通过保存它们的解来避免重复计算,最终通过组合这些子问题的解来得到原问题的解。

        理解:1. 减少重复计算        2.用小问题叠加解决大问题


//动态规划
int dynamic_3(int n){int dp[n+1];dp[0] = 1;dp[1] = 1;for(int i = 2; i<n+1;i++){dp[i] = dp[i-1] + dp[i-2];}return dp[n];
}

总代码:


int dynamic(int n){if(n == 1) return 1;else if(n == 2) return 2;else{ //大于阶梯数//方法有 f(n) = f(n -1) + f(n - 2);return dynamic(n-1) + dynamic(n-2);}
}int dynamic_1(int i, int a1, int a2,int n){if(i == 1){a1 = 0;a2 = 1;}if(i >= n) return a1+a2;else return dynamic_1(i+1, a2, a1+a2,n);
}int num[3] = {0,0,0};
int dynamic_2(int i, int n){//更新数据if(i == 1){num[0] = 0;num[1] = 1;num[2] = num[0] + num[1];}else{num[0] = num[1];num[1] = num[2];num[2] = num[0] + num[1];}if(i >= n) return num[2];else return dynamic_2(i+1,n);
}//动态规划
int dynamic_3(int n){int dp[n+1];dp[0] = 1;dp[1] = 1;for(int i = 2; i<n+1;i++){dp[i] = dp[i-1] + dp[i-2];}return dp[n];
}int climbStairs(int n) {//return dynamic(n);//return dynamic_1(1,0,0,n);//return dynamic_2(1,n);return dynamic_3(n);
}

总结:

        了解动态规划,减小运行时间,在题目越来越难的情况下,原本的暴力手段已经不足以解决问题,只有通过学习不同的算法才能完成更高难度的题目,以下是本次总结。

不足之处:

  1. 递归方法 (dynamic 和 dynamic_1):

    • 使用递归方式解决问题,但存在效率问题,特别是对于较大的输入值。
    • 在 dynamic_1 中,变量传递方式可能不够清晰。
  2. 递归方法使用全局变量 (dynamic_2):

    • 使用全局变量 num 来存储中间结果,避免了重复计算。
    • 全局变量的使用增加了代码的复杂性和维护难度。
  3. 动态规划方法 (dynamic_3):

    • 使用动态规划来解决问题,避免了递归中的重复计算问题。
    • 效率较高,适用于大规模问题的解决。

改进建议:

  1. 优化效率:

    • 对于递归方法,考虑使用记忆化搜索来避免重复计算,提高效率。
  2. 改进代码结构:

    • 改进变量传递方式,使代码更清晰易懂。
    • 避免使用全局变量,可以通过参数传递或者结构体来管理状态。
  3. 代码质量提升:

    • 添加适当的注释和更具描述性的命名,以提高代码的可读性。
    • 实现错误处理机制,确保代码的健壮性和稳定性。

参考资料:

看一遍就理解:动态规划详解

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/826228.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何使用ArcGIS Pro进行路径分析

路径分析是一种空间分析技术&#xff0c;用于确定两个或多个地点之间最佳路径或最短路径&#xff0c;这里为大家介绍一下在ArcGIS Pro中如何进行路径分析&#xff0c;希望能对你有所帮助。 数据来源 教程所使用的数据是从水经微图中下载的道路数据&#xff0c;除了道路数据&a…

阿里TTl使用管理日志

在管理日志的时候我们需要查看生成日志都是那些人干了那些事&#xff0c;那么怎么在日志上查看这些事情呢&#xff0c;首先呢可以直接使用Slf4j,然后再配置文件里配置一下 #日志文件最大上限 logging.file.max-size100MB #日志文件存储位置 logging.file.path./logs #日志文件…

中颖51芯片学习7. ADC模数转换

中颖51芯片学习7. ADC模数转换 一、ADC工作原理简介1. 概念2. ADC实现方式3. 基准电压 二、中颖芯片ADC功能介绍1. 中颖芯片ADC特性2. ADC触发源&#xff08;1&#xff09;**软件触发**&#xff08;2&#xff09;**TIMER4定时器触发**&#xff08;3&#xff09;**外部中断2触发…

面试: 悲观锁和乐观锁

一、悲观锁的代表是synchronized和Lock 锁 其核心思想是【线程只有占有了锁&#xff0c;才能去操作共享变量&#xff0c;每次只有一个线程占锁成功&#xff0c;获取锁失败的线程&#xff0c;都得停下来等待】线程从运行到阻塞、再从阻塞到唤醒&#xff0c;涉及线程上下文切换&a…

CTFHub(web sql注入)(三)

MYSQL 手工注入 1.判断字段数 输入1 输入2 输入3 得知字段有两个 2.判断注入类型 1 and 1 1 1 and 12 回显错误&#xff0c;说明存在sql注入 3.查看数据库内容 知道字段数量为2后&#xff0c;可以查看数据库位置 1 union select 1,2 使用union select 1,2查看未发现数…

【Java基础】21.重写(Override)与重载(Overload)

文章目录 一、重写(Override)1.方法重写2.方法的重写规则3.Super 关键字的使用 二、重载(Overload)1.方法重载2.重载规则3.实例 三、重写与重载之间的区别 一、重写(Override) 1.方法重写 重写&#xff08;Override&#xff09;是指子类定义了一个与其父类中具有相同名称、参…

阿里云OSS 存储对象的注册与使用

目录 一、什么是阿里云OSS 二、 点击免费试用 2.1 选择第一个&#xff0c;点击免费试用 ​编辑 2.2 登录管理控制台 2.3 进入Bucket 2.4、在阿里云网站上的个人中心配置Accesskey,查询accessKeyId和accessKeySecret。 2.5、进入AccssKey管理页面应该会出现下图提示&…

【VI/VIM】基本操作备忘录

简介 新建/打开文件 工作模式 常用命令 移动命令 文本选中 撤销、删除 复制粘贴 替换 缩排 查找 替换 插入 分屏 练习

【动态规划】C++简单多状态dp问题(打家劫舍、粉刷房子、买卖股票的最佳时机...)

文章目录 前言1. 前言 - 理解动态规划算法2. 关于 简单多状态的dp问题2.5 例题按摩师/打家劫舍 3. 算法题3.1_打家劫舍II3.2_删除并获得点数3.3_粉刷房子3.4_买卖股票的最佳时机含冷冻期3.5_买卖股票的最佳时机含手续费3.6_买卖股票的最佳时机III3.7_买卖股票的最佳时机IV 前言…

交换机的种类有哪些?主要都具有哪些作用?

在当今数字化时代&#xff0c;网络已经成为我们生活和工作中不可或缺的一部分。无论是家庭网络还是企业网络&#xff0c;都需要有效的网络设备来实现数据通信和资源共享。而网络交换机作为一种重要的网络设备&#xff0c;扮演着连接和管理网络设备的关键角色。本文将探讨交换机…

开源贡献代码之​探索一下CPython

探索一下Cython 本篇文章将会围绕最近给Apache提的一个feature为背景&#xff0c;展开讲讲CPython遇到的问题&#xff0c;以及尝试自己从0写一个库出来&#xff0c;代码也已经放星球了&#xff0c;感兴趣的同学可以去下载学习。 0.背景 最近在给apache arrow提的一个feature因为…

《TinyLlama: An Open-Source Small Language Model》全文翻译

【Title】 TinyLlama&#xff1a;开源小语言模型 【Abstract】 我们推出了 TinyLlama&#xff0c;这是一个紧凑的 1.1B 语言模型&#xff0c;在大约 1 万亿个令牌上进行了大约 3 个时期的预训练。 TinyLlama 基于 Llama 2&#xff08;Touvron 等人&#xff0c;2023b&#xff…

VUE项目使用.env配置多种环境以及如何加载环境

第一步&#xff0c;创建多个环境配置文件 Vue CLI 项目默认使用 .env 文件来定义环境变量。你可以通过创建不同的 .env 文件来为不同环境设置不同的环境变量&#xff0c;例如&#xff1a; .env —— 所有模式共用.env.local —— 所有模式共用&#xff0c;但不会被 git 提交&…

C语言 三目运算符

C语言 逻辑分支语句中 还有一种 三目运算符 我们编写代码如下 #include <stdio.h>int main() {const char* a 1 1 ? "表达式1" : "表达式2";printf("%s", a);return 0; }这里 我们根据逻辑 先定义一个a 然后 它的值 等于一个 三目运算…

【CodeGeeX】国产的免费AI编程助手

CodeGeeX&#xff08;官网&#xff1a;https://codegeex.cn/&#xff09;是一款基于大模型的全能的智能编程助手。它可以实现代码的生成与补全、自动添加注释、代码翻译以及智能问答等功能&#xff0c;能够帮助开发者显著提高工作效率。CodeGeeX支持主流的编程语言&#xff0c;…

C++练级之路——类和对象(下)

目录 1、构造函数初始化列表 2、类型转换 3、explicit关键字 4、static成员 5、友元 友元函数 友元类 6、内部类 7、匿名对象 8、拷贝构造时的一些编译器优化 差不多结束了&#xff0c;类和对象&#xff01; 1、构造函数初始化列表 初始化列表&#xff1a;以一个冒号…

python:元组,字符串,切片

一、元组# 列表可以修改内容&#xff0c;元组可以不被修改 # 在程序内封装数据&#xff0c;不希望数据被篡改&#xff0c;所以使用元组 # 语法&#xff1a; 不限制类型 # 定于元组的字面量&#xff1a; &#xff08;元素&#xff0c;元素&#xff0c;元素.....&#xff09; # 定…

萌新_1 环境安装(基于QQNT框架 Python Flask)

遇到问题加QQ群聊 群主在线解答 点击加入群聊【星辰开发】 一&#xff1a;安装QQ 目前为开发&#xff0c;推荐都安装到一台电脑上 直接安装到本地windows电脑&#xff0c; 优点方便开发 一键安装 Windows 用户一键安装方案 https://github.com/super1207/install_llob/rel…

LLMs——扩展数据受限的语言模型解决方案

概述 在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;大型语言模型的发展一直是研究的热点。这些模型通过增加参数数量和训练数据量来提升性能&#xff0c;但这种增长趋势是否会有一个极限&#xff1f;实际上&#xff0c;研究者们已经注意到&#xff0c;为了有效地…

大话设计模式-依赖倒转原则

依赖倒转原则 在大话设计模式这本书中&#xff0c;作者通过电话修电脑这个例子引入了面向对象设计的基本原则之一&#xff1a;依赖倒转原则。 概念 依赖倒转原则是面向对象设计的基本原则之一&#xff0c;它用于减少类之间的耦合&#xff0c;提高系统的灵活性和可维护性。在…