算法学习:递归搜索与动态规划 笔记合集

算法学习:递归搜索与动态规划 笔记合集

好的,我将对您提供的内容进行整理和补充,以便更全面地了解和理解这些算法。

买卖股票的最佳时机

在买卖股票的最佳时机问题中,我们需要找到买入和卖出股票的最佳时机以获得最大利润。这个问题可以分为两个子问题:

  1. 单次买卖股票的最大利润

    • 给定一个数组 prices,其中 prices[i] 表示第 i 天的股票价格。
    • 只允许完成一次交易(即只买入和卖出一次)。

    解题思路:

    • 使用动态规划来记录每一天结束时的最大利润。
    • 初始化一个二维数组 dp,其中 dp[i][j] 表示第 i 天持有/不持有股票的最大利润。
    • 状态转移方程:
      • dp[i][0] = max(dp[i-1][0], dp[i-1][1] + prices[i])
      • dp[i][1] = max(dp[i-1][1], -prices[i])
  2. 多次买卖股票的最大利润

    • 给定一个数组 prices,其中 prices[i] 表示第 i 天的股票价格。
    • 允许完成尽可能多的交易(即可以无限次买入和卖出)。

    解题思路:

    • 使用动态规划来记录每一天结束时的最大利润。
    • 初始化一个二维数组 dp,其中 dp[i][j] 表示第 i 天持有/不持有股票的最大利润。
    • 状态转移方程:
      • dp[i][0] = max(dp[i-1][0], dp[i-1][1] + prices[i])
      • dp[i][1] = max(dp[i-1][1], dp[i-1][0] - prices[i])
  3. 买卖股票的最佳时机含冷冻期

    • 给定一个数组 prices,其中 prices[i] 表示第 i 天的股票价格。
    • 允许完成尽可能多的交易(即可以无限次买入和卖出),但每次交易后需要冷静一天。

    解题思路:

    • 使用动态规划来记录每一天结束时的最大利润。
    • 初始化一个二维数组 dp,其中 dp[i][j] 表示第 i 天持有/不持有股票的最大利润。
    • 状态转移方程:
      • dp[i][0] = max(dp[i-1][0], dp[i-2][1] + prices[i])
      • dp[i][1] = max(dp[i-1][1], dp[i-1][0] - prices[i])

Floyd算法

Floyd算法(Floyd-Warshall algorithm)用于计算图中各顶点之间的最短路径。其基本思想是通过逐步增加中间顶点,不断更新两点之间的距离。

具体步骤如下:

  1. 初始化

    • 创建一个二维数组 e,其中 e[i][j] 表示从 i 号顶点到 j 号顶点的最短路径长度。
    • 初始化 e[i][j] = graph[i][j],即直接相邻的两点之间的距离。
  2. 迭代

    • 遍历所有可能的中间顶点 k(1 到 n)。
    • 对于每一对顶点 (i, j),检查通过 k 作为中转点是否能获得更短的路径。
    • 更新 e[i][j] = min(e[i][j], e[i][k] + e[k][j])
  3. 结果

    • 最终,e[i][j] 中存储的就是从 i 号顶点到 j 号顶点的最短路径长度。

示例代码:

function floydWarshall(graph) { let n = graph.length; let e = Array.from(Array(n), () => Array(n).fill(Infinity)); // 初始化 for (let i = 0; i < n; i++) { for (let j = 0; j < n; j++) { e[i][j] = graph[i][j]; } } // 迭代 for (let k = 0; k < n; k++) { for (let i = 0; i < n; i++) { for (let j = 0; j < n; j++) { e[i][j] = Math.min(e[i][j], e[i][k] + e[k][j]); } } } return e; } 

通过以上代码和解释,您可以更全面地理解和应用这些算法。希望这些内容对您有所帮助!如果您有任何问题或需要进一步的解释,请随时告诉我。

Read more

最新电子电气架构(EEA)调研-3

而新一代的强实时性、高确定性,以及满足CAP定理的同步分布式协同技术(SDCT),可以实现替代TSN、DDS的应用,且此技术已经在无人车辆得到验证,同时其低成本学习曲线、无复杂二次开发工作,将开发人员的劳动强度、学习曲线极大降低,使开发人员更多的去完成算法、执行器功能完善。 五、各大车厂的EEA 我们调研策略是从公开信息中获得各大车厂的EEA信息,并在如下中进行展示。 我们集中了华为、特斯拉、大众、蔚来、小鹏、理想、东风(岚图)等有代表领先性的车辆电子电气架构厂商。        1、华为 图12 华为的CCA电子电气架构              (1)华为“计算+通信”CC架构的三个平台                         1)MDC智能驾驶平台;                         2)CDC智能座舱平台                         3)VDC整车控制平台。        联接指的是华为智能网联解决方案,解决车内、车外网络高速连接问题,云服务则是基于云计算提供的服务,如在线车主服务、娱乐和OTA等。 华

By Ne0inhk
Apache IoTDB 架构特性与 Prometheus+Grafana 监控体系部署实践

Apache IoTDB 架构特性与 Prometheus+Grafana 监控体系部署实践

Apache IoTDB 架构特性与 Prometheus+Grafana 监控体系部署实践 文章目录 * Apache IoTDB 架构特性与 Prometheus+Grafana 监控体系部署实践 * Apache IoTDB 核心特性与价值 * Apache IoTDB 监控面板完整部署方案 * 安装步骤 * 步骤一:IoTDB开启监控指标采集 * 步骤二:安装、配置Prometheus * 步骤三:安装grafana并配置数据源 * 步骤四:导入IoTDB Grafana看板 * TimechoDB(基于 Apache IoTDB)增强特性 * 总结与应用场景建议 Apache IoTDB 核心特性与价值 Apache IoTDB 专为物联网场景打造的高性能轻量级时序数据库,以 “设备 - 测点” 原生数据模型贴合物理设备与传感器关系,通过高压缩算法、百万级并发写入能力和毫秒级查询响应优化海量时序数据存储成本与处理效率,同时支持边缘轻量部署、

By Ne0inhk
SQL Server 2019安装教程(超详细图文)

SQL Server 2019安装教程(超详细图文)

SQL Server 介绍) SQL Server 是由 微软(Microsoft) 开发的一款 关系型数据库管理系统(RDBMS),支持结构化查询语言(SQL)进行数据存储、管理和分析。自1989年首次发布以来,SQL Server 已成为企业级数据管理的核心解决方案,广泛应用于金融、电商、ERP、CRM 等业务系统。它提供高可用性、安全性、事务处理(ACID)和商业智能(BI)支持,并支持 Windows 和 Linux 跨平台部署。 一、获取 SQL Server 2019 安装包 1. 官方下载方式 前往微软官网注册账号后,即可下载 SQL Server Developer 版本(

By Ne0inhk