问题描述 在一个神秘的竞技场中,勇敢的探险者小青拥有两个宝箱:一个宝箱里装满了 n 个金银珠宝的数值,另一个则是一个包含 m 个神秘符文的序列。小青面临着一个挑战:在接下来的 m 轮中,他必须在这两者之间做出明智的选择,以获得最高的财富。 在每一轮(第 i 轮)中,小青可以选择从宝箱的最上面或最下面取出一个珠宝 x。然后,他会将这个珠宝的价值乘以对应的符文 c[i],并把结果累加到他的总财富中。被取出的珠宝将从宝箱中消失,接着小青会继续下一**作,直到完成 m 轮。 你的任务是帮助小青计算,在完成 m 轮挑战后,他可以获得的最高财富是多少。 输入: stones:宝箱中n个金银珠宝的数值 c:m个神秘符文 约束条件: 时间限制:3s stones 和 c序列大小的数据范围为 1 ≤ m ≤ n≤ 2000,并且 -1000 ≤ stones[i], c[i]≤ 1000 测试样例 样例1: 输入:stones = [-3, 4, 5], c = [2, -1, 3] 输出:25 样例2: 输入:stones = [6, -7, 1], c = [4, -3] 输出:45


思路: 这是一个典型的动态规划问题。 我们可以用一个二维数组dp来记录小青在每一轮中所能获得的最大财富。 dp[i][j]表示小青在第i轮取出第j个珠宝时所能获得的最大财富。 对于第i轮取出的珠宝x,有两种情况: 1. 如果取出的是最上面的珠宝,即dp[i][j] = dp[i-1][j] + stones[j] * c[i]。 2. 如果取出的是最下面的珠宝,即dp[i][j] = dp[i-1][j-1] + stones[j] * c[i]。 小青在第i轮中的最大财富就是这两种情况中的较大值。 为了使得边界情况也能适用于上述状态方程,我们可以在stones和c的前面分别插入一个0,即stones = [0] + stones,c = [0] + c。 算法流程: 1. 初始化二维数组dp,大小为(m+1)×(n+1),并将其所有元素初始化为0。 2. 将stones和c的前面插入一个0。 3. 对于i从1到m, j从1到n,进行如下操作: - 如果j == 1,即取出的是最上面的珠宝,则dp[i][j] = dp[i-1][j] + stones[j] * c[i]。 - 如果j == n,即取出的是最下面的珠宝,则dp[i][j] = dp[i-1][j-1] + stones[j] * c[i]。 - 否则,dp[i][j] = max(dp[i-1][j] + stones[j] * c[i], dp[i-1][j-1] + stones[j] * c[i])。 4. 返回dp[m][n],即最高财富。 时间复杂度分析: 由于需要遍历m×n个状态,因此时间复杂度为O(mn)。 [2024-12-07 11:39:39 | AI写代码神器 | 695点数解答]
- 问题描述 在一个神秘的竞技场中,勇敢的探险者小青拥有两个宝箱:一个宝箱里装满了 n 个金银珠宝的数值,另一个则是一个包含 m 个神秘符文的序列。小青面临着一个挑战:在接下来的 m 轮中,他必须在这两者之间做出明智的选择,以获得最高的财富。 在每一轮(第 i 轮)中,小青可以选择从宝箱的最上面或最下面取出一个珠宝 x。然后,他会将这个珠宝的价值乘以对应的符文 c[i],并把结果累加到他的总财富中。被取出的珠宝将从宝箱中消失,接着小青会继续下一**作,直到完成 m 轮。 你的任务是帮助小青计算,在完成 m 轮挑战后,他可以获得的最高财富是多少。 输入: stones:宝箱中n个金银珠宝的数值 c:m个神秘符文 约束条件: 时间限制:3s stones 和 c序列大小的数据范围为 1 ≤ m ≤ n≤ 2000,并且 -1000 ≤ stones[i], c[i]≤ 1000 测试样例 样例1: 输入:stones = [-3, 4, 5], c = [2, -1, 3] 输出:25 样例2: 输入:stones = [6, -7, 1], c = [4, -3] 输出:45(695点数解答 | 2024-12-07 11:39:39)189
- 年会表演串词,年会节目清单 1、陈德光:诗朗诵《旗帜》5分钟 2、财务、后勤部:舞蹈《谁是我的新郎》4分钟 3、销售部:演唱《苹果香》5分钟 4、游戏:诸葛帽吃糖 5个人 一轮 10分钟 5、标书、采购部:《三句半》3分钟 6、技术部:舞蹈《wave》4分钟 7、销售部:《魔术》15分钟 8、彩虹圈转光盘 (只限于男生)4个人 一轮 10分钟 9、技术部:脱口秀 20分钟 10、销售部:《吃香蕉》3分钟 11、财务、后勤部:合唱《感恩的心》4分钟 12、游戏:喊话吹蜡烛(指定人)2个人 一轮 5分钟 13、标书、采购部:朗诵《我爱上班》 3分钟 11、销售部:邓腾龙《青花瓷》4分钟 14、相声新闻晚知道10分钟 15、游戏:摸麻将4个人 一轮 5分钟 16、大合唱:相亲相爱一家人5分钟,字数:200字(206点数解答 | 2025-01-08 10:59:43)223
- 编辑距离 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定两个字符串 s s 与 t t,请计算 s s 到 t t 的编辑距离。所谓编辑距离,就是最少进行多少步修改可以将 s s 变成 t t,每次修改操作可以从以下操作选择一种: 插入一个字符 删除一个字符 替换一个字符 编辑距离是一个很重要的概念,比如: 微信公众号有个规定:已经发表的文章,只能修改 20 20 个字。所以公众号的运营人员需要仔细计算新旧文章的编辑距离。 DNA 是由 actg 四个字母组成的字符串,编辑距离可以规划编辑 DNA 的最佳方案。 输入格式 第一行:一个字符串 s s,由小写英文字符组成 第二行:一个字符串 t t,由小写英文字符组成 输出格式 单个整数:表示两个字符串的编辑距离 数据范围 1 ≤ ∣ s ∣ ≤ 2000 1≤∣s∣≤2000 1 ≤ ∣ t ∣ ≤ 2000 1≤∣t∣≤2000 样例数据 输入: atcg tcga 输出: 2 说明: 删除第一个a,然后在字符串尾部再加一个a 输入: abcdefg gfedcba 输出: 6 c++写,简单(521点数解答 | 2025-08-20 14:58:56)75
- 编辑距离 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定两个字符串 s s 与 t t,请计算 s s 到 t t 的编辑距离。所谓编辑距离,就是最少进行多少步修改可以将 s s 变成 t t,每次修改操作可以从以下操作选择一种: 插入一个字符 删除一个字符 替换一个字符 编辑距离是一个很重要的概念,比如: 微信公众号有个规定:已经发表的文章,只能修改 20 20 个字。所以公众号的运营人员需要仔细计算新旧文章的编辑距离。 DNA 是由 actg 四个字母组成的字符串,编辑距离可以规划编辑 DNA 的最佳方案。 输入格式 第一行:一个字符串 s s,由小写英文字符组成 第二行:一个字符串 t t,由小写英文字符组成 输出格式 单个整数:表示两个字符串的编辑距离 数据范围 1 ≤ ∣ s ∣ ≤ 2000 1≤∣s∣≤2000 1 ≤ ∣ t ∣ ≤ 2000 1≤∣t∣≤2000 样例数据 输入: atcg tcga 输出: 2 说明: 删除第一个a,然后在字符串尾部再加一个a 输入: abcdefg gfedcba 输出: 6 用C++写,普(586点数解答 | 2025-08-22 15:48:48)59
- 编辑距离 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定两个字符串 s s 与 t t,请计算 s s 到 t t 的编辑距离。所谓编辑距离,就是最少进行多少步修改可以将 s s 变成 t t,每次修改操作可以从以下操作选择一种: 插入一个字符 删除一个字符 替换一个字符 编辑距离是一个很重要的概念,比如: 微信公众号有个规定:已经发表的文章,只能修改 20 20 个字。所以公众号的运营人员需要仔细计算新旧文章的编辑距离。 DNA 是由 actg 四个字母组成的字符串,编辑距离可以规划编辑 DNA 的最佳方案。 输入格式 第一行:一个字符串 s s,由小写英文字符组成 第二行:一个字符串 t t,由小写英文字符组成 输出格式 单个整数:表示两个字符串的编辑距离 数据范围 1 ≤ ∣ s ∣ ≤ 2000 1≤∣s∣≤2000 1 ≤ ∣ t ∣ ≤ 2000 1≤∣t∣≤2000 样例数据 输入: atcg tcga 输出: 2 说明: 删除第一个a,然后在字符串尾部再加一个a 输入: abcdefg gfedcba 输出: 6 用C++写,普通写法,简单一点,不要(547点数解答 | 2025-08-22 15:49:32)69
- 编辑距离 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定两个字符串 s s 与 t t,请计算 s s 到 t t 的编辑距离。所谓编辑距离,就是最少进行多少步修改可以将 s s 变成 t t,每次修改操作可以从以下操作选择一种: 插入一个字符 删除一个字符 替换一个字符 编辑距离是一个很重要的概念,比如: 微信公众号有个规定:已经发表的文章,只能修改 20 20 个字。所以公众号的运营人员需要仔细计算新旧文章的编辑距离。 DNA 是由 actg 四个字母组成的字符串,编辑距离可以规划编辑 DNA 的最佳方案。 输入格式 第一行:一个字符串 s s,由小写英文字符组成 第二行:一个字符串 t t,由小写英文字符组成 输出格式 单个整数:表示两个字符串的编辑距离 数据范围 1 ≤ ∣ s ∣ ≤ 2000 1≤∣s∣≤2000 1 ≤ ∣ t ∣ ≤ 2000 1≤∣t∣≤2000 样例数据 输入: atcg tcga 输出: 2 说明: 删除第一个a,然后在字符串尾部再加一个a 输入: abcdefg gfedcba 输出: 6 用C++写,普通写法,简单一点,不要(571点数解答 | 2025-08-22 15:51:59)80
- - ItemId: 12720 #道具id A级赛车 雷诺 ItemNum: 1 #数量 ObtainTime: 1 #时间 AvailPeriod: -1 #0显示数量 -1显示永久 - ItemId: 127758 #道具id 宠物 冰凤 ItemNum: 1 #数量 ObtainTime: 1 #时间 AvailPeriod: -1 #0显示数量 -1显示永久 - ItemId: 21980 #道具id 效率宝珠LV4 ItemNum: 100 #数量 ObtainTime: 1 #时间 AvailPeriod: 0 #0显示数量 -1显示永久 - ItemId: 21986 #道具id 重生宝珠LV4 ItemNum: 100 #数量 ObtainTime: 1 #时间 AvailPeriod: 0 #0显示数量 -1显示永久 这种文本文件如何用易语言读入并显示到超级列表框内 (571点数解答 | 2025-08-23 20:54:40)86
- - ItemId: 12720 #道具id A级赛车 雷诺 ItemNum: 1 #数量 ObtainTime: 1 #时间 AvailPeriod: -1 #0显示数量 -1显示永久 - ItemId: 127758 #道具id 宠物 冰凤 ItemNum: 1 #数量 ObtainTime: 1 #时间 AvailPeriod: -1 #0显示数量 -1显示永久 - ItemId: 21980 #道具id 效率宝珠LV4 ItemNum: 100 #数量 ObtainTime: 1 #时间 AvailPeriod: 0 #0显示数量 -1显示永久 - ItemId: 21986 #道具id 重生宝珠LV4 ItemNum: 100 #数量 ObtainTime: 1 #时间 AvailPeriod: 0 #0显示数量 -1显示永久 这种文本文件如何用易语言读入并显示到超级列表框内,并且可以增加新的一样的文本(1317点数解答 | 2025-08-23 20:58:40)97
- 题目描述 请根据邮件的重量和用户选择是否加急计算邮费。计算规则: 重量在 1000 1000 以内(包括),基本费 8 8 元; 超过 1000 1000 克的部分,每 500 500 克加收超重费 4 4 元,不足 500 500 克部分按 500 500 克计算; 如果用户选择加急,多收 5 5 元。 输入格式 一行,包含一个正整数 x x 和一个字符 c(y 或 n),之间用一个空格隔开,分别表示重量和是否加急。 如果字符是 y,说明选择加急;如果字符是 n,说明不加急。 输出格式 输出一行一个正整数,表示邮费。 输入输出样例 输入 #1复制 1200 y 输出 #1复制 17 说明/提示 对于100%数据 1 ≤ x ≤ 1 0 6 1≤x≤10 6 在洛谷, 享受 coding 的欢乐(88点数解答 | 2024-11-09 15:33:30)284
- 题目描述 请根据邮件的重量和用户选择是否加急计算邮费。计算规则: 重量在 1000 1000 以内(包括),基本费 8 8 元; 超过 1000 1000 克的部分,每 500 500 克加收超重费 4 4 元,不足 500 500 克部分按 500 500 克计算; 如果用户选择加急,多收 5 5 元。 输入格式 一行,包含一个正整数 x x 和一个字符 c(y 或 n),之间用一个空格隔开,分别表示重量和是否加急。 如果字符是 y,说明选择加急;如果字符是 n,说明不加急。 输出格式 输出一行一个正整数,表示邮费。 输入输出样例 输入 #1复制 1200 y 输出 #1复制 17 说明/提示 对于100%数据 1 ≤ x ≤ 1 0 6 1≤x≤10 6 在洛谷, 享受 coding 的欢乐(554点数解答 | 2024-11-09 15:34:05)290
- 请根据邮件的重量和用户选择是否加急计算邮费。计算规则: 重量在 1000 1000 以内(包括),基本费 8 8 元; 超过 1000 1000 克的部分,每 500 500 克加收超重费 4 4 元,不足 500 500 克部分按 500 500 克计算; 如果用户选择加急,多收 5 5 元。 输入格式 一行,包含一个正整数 x x 和一个字符 c(y 或 n),之间用一个空格隔开,分别表示重量和是否加急。 如果字符是 y,说明选择加急;如果字符是 n,说明不加急。 输出格式 输出一行一个正整数,表示邮费。 输入输出样例 输入 #1复制 1200 y 输出 #1复制 17 说明/提示 对于100%数据 1 ≤ x ≤ 1 0 6 1≤x≤10 6(244点数解答 | 2024-12-31 19:36:29)209
- 目标:根据以下数据,利用线性回归模型研究商品销售量y与广告投入x的关系,写出python代码 广告投入(百万元)5.50 6.75 7.25 7.00 6.50 5.25 6.00 4.50 8.25 9.50 销售量(百万件)11.50 13.70 14.83 14.15 13.06 11.71 12.16 9.96 15.88 18.33 任务:1) 写出本问题的线性回归模型; 2) 写出相应的目标函数l; 3) 通过闭式解的方式求y与x的关系; 4) 利用梯度下降法求y与x的关系; 5) 预测广告投入为1千万元时,商品的销售量情况。(712点数解答 | 2024-11-18 20:44:33)206