当前位置: 首页 > news >正文

WordPress分类目录 前100篇快速整站优化

WordPress分类目录 前100篇,快速整站优化,网站访客qq抓取原理,sap仓库管理系统目录 1. 买卖股票的最佳时机2. 打家劫舍 II 1. 买卖股票的最佳时机 🔗 原题链接:121. 买卖股票的最佳时机 假设在第 i i i 天卖出股票可获得最大利润,那么买入股票必然是在前 i − 1 i-1 i−1 天中的某一天。更进一步,买入股票应…

目录

  • 1. 买卖股票的最佳时机
  • 2. 打家劫舍 II

1. 买卖股票的最佳时机

🔗 原题链接:121. 买卖股票的最佳时机

假设在第 i i i 天卖出股票可获得最大利润,那么买入股票必然是在前 i − 1 i-1 i1 天中的某一天。更进一步,买入股票应当是第 arg min ⁡ 0 ≤ x ≤ i − 2 a [ x ] \argmin_{0\leq x\leq i-2} a[x] argmin0xi2a[x] 天。这说明我们可以维护一个 minprice 的变量,这样一来,a[i] - minprice 就代表在第 i i i 天卖出股票能够获得的最大利润。

class Solution {
public:int maxProfit(vector<int>& prices) {int minprice = 1e9;int ans = 0;for (auto& price: prices) {minprice = min(minprice, price);ans = max(ans, price - minprice);}return ans;}
};

2. 打家劫舍 II

先回顾第一代的打家劫舍。

🔗 原题链接:198. 打家劫舍

考虑使用dp。我们用 dp[i] 来代表偷前 i i i 家能够获得的最大金额,那么我们可以按照第 i i i 个元素的情况对 dp[i] 进行划分。

  • 偷窃第 i i i 间房屋,那么就不能偷窃第 i − 1 i-1 i1 间房屋,偷窃总金额为前 i − 2 i-2 i2 间房屋的最高总金额与第 i i i 间房屋的金额之和。
  • 不偷窃第 i i i 间房屋,偷窃总金额为前 i − 1 i-1 i1 间房屋的最高总金额。

转移方程为:

d p [ i ] = m a x ( d p [ i − 2 ] + n u m s [ i ] , d p [ i − 1 ] ) dp[i]=max(dp[i-2]+nums[i], \,dp[i-1]) dp[i]=max(dp[i2]+nums[i],dp[i1])

class Solution {
public:int rob(vector<int>& nums) {int n = nums.size();if (n == 0) return 0;if (n == 1) return nums[0];vector<int> dp(n);dp[0] = nums[0];dp[1] = max(nums[0], nums[1]);for (int i = 2; i < n; i++) {dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);}return dp[n - 1];}
};

下面回到本题。

🔗 原题链接:213. 打家劫舍 II

假如偷第 0 0 0 间房屋,那么剩下可以偷窃的范围就是 [ 2 , n − 2 ] [2,n-2] [2,n2];假如不偷第 0 0 0 间房屋,那么剩下可以偷窃的范围就是 [ 1 , n − 1 ] [1,n-1] [1,n1]。取两者中的最大值就是本题答案。

class Solution {
public:int rob(vector<int>& nums) {int n = nums.size();if (n == 1) return nums[0];if (n == 2) return max(nums[0], nums[1]);vector<int> a(nums.begin() + 2, nums.begin() + n - 1);int price1 = rob1(a) + nums[0];vector<int> b(nums.begin() + 1, nums.begin() + n);int price2 = rob1(b);return max(price1, price2);}int rob1(vector<int>& nums) {int n = nums.size();if (n == 0) return 0;if (n == 1) return nums[0];vector<int> dp(n);dp[0] = nums[0];dp[1] = max(nums[0], nums[1]);for (int i = 2; i < n; i++) {dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);}return dp[n - 1];}
};

此外,还可以使用滚动数组将空间复杂度优化至 O ( 1 ) O(1) O(1),这里从略。

http://www.hkea.cn/news/465247/

相关文章:

  • 东莞做网站企业铭会员制营销
  • 做网站设计工资多少钱优化教程网官网
  • 计算机网站建设与维护百度关键词统计
  • wordpress网站实现微信登录google google
  • 网站建设 零基础网站关键词如何优化
  • 如何撤销网站上信息app网站
  • 单页式网站系统每日新闻摘要30条
  • 网站开发公司 广告词优化方案电子版
  • 做便民工具网站怎么样关键词挖掘站长工具
  • 纺织面料做哪个网站好百度站长资源
  • 菏泽网站建设哪好怎样做平台推广
  • 网上有做logo的网站吗网络营销的核心是什么
  • 自建网站怎么做推广微信营销策略
  • 跳网站查询的二维码怎么做的关键词排名点击软件网站
  • 兼容手机的网站百度怎么推广自己的视频
  • 宝安中心医院入职体检跟我学seo
  • 企业网站后端模板石家庄疫情最新情况
  • 沈阳哪家网站做的好网络营销是指什么
  • 我的网站模板网站建设主要推广方式
  • 国外app素材网站seo运营是做什么的
  • 企业网站seo怎么做百度帐号个人中心
  • 郑州网站建设亅汉狮网络百度网盘seo优化
  • 模板型网站seo优化平台
  • 官方网站下载免费软件培训机构有哪些?哪个比较好
  • 网站导航怎么做的惠州seo计费管理
  • 建设公司网站模板全国唯一一个没有疫情的城市
  • 网站怎么做seo_南京百度提升优化
  • 旅游网站开发与设计论文怎么样建网站
  • 北京网站推广排名公司企业网站的搜索引擎推广与优化
  • 动态网站期末设计广告营销策略