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

linux搭建个人网站营销策略从哪几个方面分析

linux搭建个人网站,营销策略从哪几个方面分析,内部网站建设依据文件,绍兴专业制作网站代码随想录算法训练营第四十八天 | 198.打家劫舍,213.打家劫舍II,337.打家劫舍III 198.打家劫舍213.打家劫舍II337.打家劫舍III 198.打家劫舍 题目链接 视频讲解 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff…

代码随想录算法训练营第四十八天 | 198.打家劫舍,213.打家劫舍II,337.打家劫舍III

  • 198.打家劫舍
  • 213.打家劫舍II
  • 337.打家劫舍III

198.打家劫舍

题目链接
视频讲解
你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警,给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额

输入:[2,7,9,3,1]
输出:12

确定dp数组(dp table)以及下标的含义
dp[i]:考虑下标i(包括i)以内的房屋,最多可以偷窃的金额为dp[i]
确定递推公式
决定dp[i]的因素就是第i房间偷还是不偷
如果偷第i房间,那么dp[i] = dp[i - 2] + nums[i] ,即:第i-1房一定是不考虑的,找出 下标i-2(包括i-2)以内的房屋,最多可以偷窃的金额为dp[i-2] 加上第i房间偷到的钱
如果不偷第i房间,那么dp[i] = dp[i - 1],即考 虑i-1房,(注意这里是考虑,并不是一定要偷i-1房,这是很多同学容易混淆的点)
然后dp[i]取最大值,即dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);
dp数组如何初始化
从递推公式dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);可以看出,递推公式的基础就是dp[0] 和 dp[1]
从dp[i]的定义上来讲,dp[0] 一定是 nums[0],dp[1]就是nums[0]和nums[1]的最大值即:dp[1] = max(nums[0], nums[1]);
代码如下:

vector<int> dp(nums.size());
dp[0] = nums[0];
dp[1] = max(nums[0], nums[1]);

确定遍历顺序
dp[i] 是根据dp[i - 2] 和 dp[i - 1] 推导出来的,那么一定是从前到后遍历!
代码如下:

for (int i = 2; i < nums.size(); i++) {dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);
}

举例推导dp数组
以示例二,输入[2,7,9,3,1]为例

在这里插入图片描述
红框dp[nums.size() - 1]为结果

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

213.打家劫舍II

题目链接
视频讲解
你是一个专业的小偷,计划偷窃沿街的房屋,每间房内都藏有一定的现金,这个地方所有的房屋都 围成一圈 ,这意味着第一个房屋和最后一个房屋是紧挨着的,同时,相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警
给定一个代表每个房屋存放金额的非负整数数组,计算你 在不触动警报装置的情况下 ,今晚能够偷窃到的最高金额

输入:nums = [1,2,3,1]
输出:4

这道题目和198.打家劫舍是差不多的,唯一区别就是成环了,对于一个数组,成环的话主要有如下三种情况:
情况一:考虑不包含首尾元素
在这里插入图片描述
情况二:考虑包含首元素,不包含尾元素
在这里插入图片描述
情况三:考虑包含尾元素,不包含首元素
在这里插入图片描述
注意这里用的是"考虑",例如情况三,虽然是考虑包含尾元素,但不一定要选尾部元素! 对于情况三,取nums[1] 和 nums[3]就是最大的而情况二 和 情况三 都包含了情况一了,所以只考虑情况二和情况三就可以了
代码如下:

class Solution {
public:int rob(vector<int>& nums) {if (nums.size() == 0) return 0;if (nums.size() == 1) return nums[0];int result1 = robRange(nums, 0, nums.size() - 2); // 情况二int result2 = robRange(nums, 1, nums.size() - 1); // 情况三return max(result1, result2);}// 198.打家劫舍的逻辑int robRange(vector<int>& nums, int start, int end) {if (end == start) return nums[start];vector<int> dp(nums.size());dp[start] = nums[start];dp[start + 1] = max(nums[start], nums[start + 1]);for (int i = start + 2; i <= end; i++) {dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);}return dp[end];}
};

337.打家劫舍III

题目链接
视频讲解
小偷又发现了一个新的可行窃的地区。这个地区只有一个入口,我们称之为 root,除了 root 之外,每栋房子有且只有一个“父“房子与之相连,一番侦察之后,聪明的小偷意识到“这个地方的所有房屋的排列类似于一棵二叉树”,如果 两个直接相连的房子在同一天晚上被打劫 ,房屋将自动报警,给定二叉树的 root,返回 在不触动警报的情况下 ,小偷能够盗取的最高金额
在这里插入图片描述

输入: root = [3,2,3,null,3,null,1]
输出: 7 

确定递归函数的参数和返回值
这里我们要求一个节点 偷与不偷的两个状态所得到的金钱,那么返回值就是一个长度为2的数组
参数为当前节点,代码如下:
vector robTree(TreeNode* cur) {
其实这里的返回数组就是dp数组
所以dp数组(dp table)以及下标的含义:下标为0记录不偷该节点所得到的的最大金钱,下标为1记录偷该节点所得到的的最大金钱
所以本题dp数组就是一个长度为2的数组!
那么长度为2的数组怎么标记树中每个节点的状态呢?
别忘了在递归的过程中,系统栈会保存每一层递归的参数
确定终止条件
在遍历的过程中,如果遇到空节点的话,很明显,无论偷还是不偷都是0,所以就返回if (cur == NULL) return vector{0, 0};这也相当于dp数组的初始化
确定遍历顺序
首先明确的是使用后序遍历,因为要通过递归函数的返回值来做下一步计算
通过递归左节点,得到左节点偷与不偷的金钱
通过递归右节点,得到右节点偷与不偷的金钱
代码如下:

// 下标0:不偷,下标1:偷
vector<int> left = robTree(cur->left); // 左
vector<int> right = robTree(cur->right); // 右
// 中

确定单层递归的逻辑
如果是偷当前节点,那么左右孩子就不能偷,val1 = cur->val + left[0] + right[0]; (如果对下标含义不理解就再回顾一下dp数组的含义)
如果不偷当前节点,那么左右孩子就可以偷,至于到底偷不偷一定是选一个最大的,所以:val2 = max(left[0], left[1]) + max(right[0], right[1]);
最后当前节点的状态就是{val2, val1}; 即:{不偷当前节点得到的最大金钱,偷当前节点得到的最大金钱}
代码如下:

vector<int> left = robTree(cur->left); // 左
vector<int> right = robTree(cur->right); // 右
// 偷cur
int val1 = cur->val + left[0] + right[0];
// 不偷cur
int val2 = max(left[0], left[1]) + max(right[0], right[1]);
return {val2, val1};

举例推导dp数组
以示例1为例,dp数组状态如下:(注意用后序遍历的方式推导)
在这里插入图片描述
最后头结点就是 取下标0 和 下标1的最大值就是偷得的最大金钱

class Solution {
public:int rob(TreeNode* root) {vector<int> result = robTree(root);return max(result[0], result[1]);}// 长度为2的数组,0:不偷,1:偷vector<int> robTree(TreeNode* cur) {if (cur == NULL) return vector<int>{0, 0};vector<int> left = robTree(cur->left);vector<int> right = robTree(cur->right);// 偷cur,那么就不能偷左右节点。int val1 = cur->val + left[0] + right[0];// 不偷cur,那么可以偷也可以不偷左右节点,则取较大的情况int val2 = max(left[0], left[1]) + max(right[0], right[1]);return {val2, val1};}
};
http://www.dinnco.com/news/26710.html

相关文章:

  • 爬虫做网站相关教程惠州seo报价
  • 一个购物网站多少钱免费做网站网站
  • 做网站标语网站优化招聘
  • 网站怎么做语言切换济南seo网站关键词排名
  • 互联网金融网站建设推广软文发布平台
  • 明空网络做网站好不好百度100%秒收录
  • wordpress哪个版本php青岛谷歌优化
  • 青岛网站优化联系方式seo常见的优化技术
  • 专业网站建设效果显著淘宝关键词排名优化
  • 网站绿色色调设计百度快速排名软件原理
  • net网站开发实例武汉网站运营专业乐云seo
  • 女同性怎么做的视频网站今日新闻联播
  • 中央人民政府网网址seo顾问培训
  • 网站建设河南图片识别搜索引擎
  • 苏州加基森网站建设竞价推广账户托管费用
  • 网站怎么做架构短视频营销推广方式
  • 东莞好的网站建设公司关键词异地排名查询
  • 国内一线互联网公司排名优化大师win10能用吗
  • 30g月流量网站苹果要做搜索引擎
  • wordpress 腾讯cos优化seo设置
  • 专门做网站的软件成都网站建设方案优化
  • 如何用wampp 做网站广东深圳疫情最新消息
  • 关于做网站的策划书seo网站诊断
  • 刷信誉网站制作站长推荐入口自动跳转
  • 最吸引人的营销广告词星乐seo网站关键词排名优化
  • 我是这样做网站的米课百度自媒体平台
  • 做杂志的模板下载网站有哪些seo价格查询公司
  • 那个网站做二手车好alexa排名查询
  • 网站pc端和手机端分离怎么做数据分析师报考条件
  • 个人空间网站建设合肥网站制作