动态规划
文章平均质量分 80
忆几度长安
樱木花道最棒了。
刚来不久,记录自己学习过的知识,希望能多和大家共同进步。
展开
-
动态规划C++实现--换钱的方法数(一)(暴力递归 和 记忆化搜索)
题目:换钱的方法数 给定数组 arr, arr中所有的值都为正数且不重复。每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个整数aim代表要找的钱数,求换钱有多少种方法。将原文的伪代码进行C++实现程序员代码面试指南第四章递归和动态规划 点击打开链接例1:arr = [5, 10, 25, 1] ,aim = 15, 6种方法1) 3张5元; 2)1张10元+1张5元...原创 2018-04-22 00:01:58 · 1378 阅读 · 0 评论 -
动态规划C++实现--换钱的方法数(二)(动态规划及其改进方法)
题目:换钱的方法数 给定数组 arr, arr中所有的值都为正数且不重复。每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个整数aim代表要找的钱数,求换钱有多少种方法。将原文的伪代码进行C++实现程序员代码面试指南第四章递归和动态规划 点击打开链接例1:arr = [5, 10, 25, 1] ,aim = 15, 6种方法1) 3张5元; 2)1张10元+1张5元...原创 2018-04-22 10:57:27 · 1091 阅读 · 2 评论 -
动态规划C++实现--字符串的交错组成
题目:字符串的交错组成 给定三个字符串 str1, str2 和 aim,如果 aim 包含仅包含来自 str1 和 str2的所有字符,而且在 aim 中属于str1的字符之间保持原来在 str1 的顺序,属于str2的字符之间保持原来 str2 的顺序,那么称 aim 是 str1 和 str2的交错组成。实现一个函数,判断aim是否是 str1 和 str2 交错组成。说明: ...原创 2018-05-18 11:32:56 · 641 阅读 · 0 评论 -
动态规划C++实现--龙与地下城游戏
题目:龙与地下城游戏 给定一个二维数组map,含义是一张地图,例如,如下矩阵: -2 -3 1 -5 -10 1 0 30 -5 游戏的规则如下:骑士从左上角出发,每次只能向右或向下走,最后到达右下角见到公主。地图中每个位置的值代表骑士要遭遇的事情。如果是负数,说明此处有怪兽,要让骑士损失血量。如果是...原创 2018-05-18 22:05:15 · 1226 阅读 · 1 评论 -
动态规划C++实现--换钱的最少货币数
题目:换钱的方法数 给定数组 arr, arr中所有的值都为正数且不重复。每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个整数aim代表要找的钱数,求组成aim的最少货币数。举例:arr=[5, 2, 3] , aim = 20. 4张5元可以组成20元。返回 4arr=[5, 2, 3] , aim = 0 不使用货币,返回 0arr=[3...原创 2018-05-14 11:45:06 · 2060 阅读 · 0 评论 -
动态规划C++实现--最长递增子序列
题目: 给定数组arr, 返回arr的最长递增子序列。举例:arr = [2, 1, 5, 3, 6, 4, 8, 9, 7], 返回的最长递增子序列为 [1, 3, 4, 8, 9]要求:如果arr长度为N,请实现时间复杂度为O(NlogN)的方法。一、 先介绍时间复杂度O(N^2)的方法,具体过程如下:1. 生成长度为N的数组dp, dp[i]表示在以arr[i]这个数结尾的情况下,arr[0...原创 2018-05-15 11:43:36 · 14128 阅读 · 2 评论 -
动态规划C++实现--最小编辑代价
题目:给定两个字符串 str1 和 str2,再给定三个整数 ic, dc 和 rc,分别代表插入、删除和替换1个字符的代价, 返回 str1 编辑成 str2 的代价。举例: str1 = "abc", str2 = "adc", ic = 5, dc = 3, rc = 2. : "b"替换成"d"代价为 2 str1 = "abc", str...原创 2018-05-15 20:41:18 · 1186 阅读 · 0 评论