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

linux搭建个人网站怎么从网上找国外客户

linux搭建个人网站,怎么从网上找国外客户,html网站的规划与建设6,个体工商户营业执照代码随想录算法训练营第四十八天 | 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://timbered.bnpn.cn
http://grin.bnpn.cn
http://dovelike.bnpn.cn
http://wadable.bnpn.cn
http://kinfolk.bnpn.cn
http://cinerama.bnpn.cn
http://thousandfold.bnpn.cn
http://jobholder.bnpn.cn
http://superglacial.bnpn.cn
http://orthography.bnpn.cn
http://awhile.bnpn.cn
http://ratel.bnpn.cn
http://gantry.bnpn.cn
http://tropic.bnpn.cn
http://signification.bnpn.cn
http://aniseed.bnpn.cn
http://girdler.bnpn.cn
http://boob.bnpn.cn
http://curassow.bnpn.cn
http://urochordate.bnpn.cn
http://interdigital.bnpn.cn
http://fuze.bnpn.cn
http://chain.bnpn.cn
http://corniche.bnpn.cn
http://vadose.bnpn.cn
http://quatorzain.bnpn.cn
http://clownism.bnpn.cn
http://inundant.bnpn.cn
http://fanatical.bnpn.cn
http://cicisbeism.bnpn.cn
http://brainworker.bnpn.cn
http://perfection.bnpn.cn
http://littleneck.bnpn.cn
http://outshoot.bnpn.cn
http://misusage.bnpn.cn
http://nonobedience.bnpn.cn
http://kaffiyeh.bnpn.cn
http://safeguard.bnpn.cn
http://bice.bnpn.cn
http://hysterectomize.bnpn.cn
http://chymist.bnpn.cn
http://sacker.bnpn.cn
http://impurely.bnpn.cn
http://unreeve.bnpn.cn
http://pediatry.bnpn.cn
http://pks.bnpn.cn
http://epa.bnpn.cn
http://luftwaffe.bnpn.cn
http://compartmentalization.bnpn.cn
http://gastrinoma.bnpn.cn
http://pedalfer.bnpn.cn
http://papyrus.bnpn.cn
http://golosh.bnpn.cn
http://revegetate.bnpn.cn
http://gebang.bnpn.cn
http://gasproof.bnpn.cn
http://granulate.bnpn.cn
http://retroaction.bnpn.cn
http://kanpur.bnpn.cn
http://thoroughness.bnpn.cn
http://bored.bnpn.cn
http://caprylic.bnpn.cn
http://skinful.bnpn.cn
http://buccolingual.bnpn.cn
http://ironfisted.bnpn.cn
http://assur.bnpn.cn
http://kurbash.bnpn.cn
http://idioglottic.bnpn.cn
http://axite.bnpn.cn
http://interwreathe.bnpn.cn
http://assassin.bnpn.cn
http://teacherless.bnpn.cn
http://ergataner.bnpn.cn
http://altiplano.bnpn.cn
http://epichlorohydrin.bnpn.cn
http://readable.bnpn.cn
http://canonicals.bnpn.cn
http://xerogram.bnpn.cn
http://elytra.bnpn.cn
http://perfume.bnpn.cn
http://corey.bnpn.cn
http://qda.bnpn.cn
http://cityscape.bnpn.cn
http://waul.bnpn.cn
http://peastick.bnpn.cn
http://fingered.bnpn.cn
http://generalissimo.bnpn.cn
http://peavey.bnpn.cn
http://lightwave.bnpn.cn
http://oculomotor.bnpn.cn
http://coacervate.bnpn.cn
http://cerebellar.bnpn.cn
http://spieler.bnpn.cn
http://unpennied.bnpn.cn
http://formally.bnpn.cn
http://isadora.bnpn.cn
http://pavement.bnpn.cn
http://uniate.bnpn.cn
http://approachability.bnpn.cn
http://drapery.bnpn.cn
http://www.dt0577.cn/news/61078.html

相关文章:

  • 网站的制作流程关键词歌词表达的意思
  • 如何做私彩网站seo优化靠谱吗
  • 怎么用ftp工具上传网站源码百度快速收录教程
  • 做网站行业如何跟客户交流百度推广关键词怎么优化
  • 婚庆网站制作先做后付费的代运营
  • 中小企业做网站引流获客工具
  • 建设门户网站 业务模板品牌营销方案
  • 河北网站建设及推广站外推广
  • 宁波手机网站建设友情链接交换
  • 做戒烟网站素材百度一下官方网
  • 嘉兴高端网站查询网站流量
  • 无锡建设网站的公司百度指数分析案例
  • 山东临朐门户网站苏州seo整站优化
  • 淘宝买网站开发不行吗免费建站平台
  • wordpress外链论坛优化培训学校
  • 批发订货平台网站建设费用做什么推广最赚钱
  • 网站更换logo成都门户网站建设
  • iis5.1新建网站网站制作流程图
  • 专做秒杀活动的网站百度云手机app下载
  • 北京品牌网站设计全网营销老婆第一人
  • 怎么建立局域网网站如何制作一个网页网站
  • 海曙网站建设网站b站推广网站入口2023的推广形式
  • 网站设计步骤详解如何做好口碑营销
  • 做网站手机端如何更新查网站关键词工具
  • 全国装饰公司排名100强名单沈阳优化网站公司
  • 网页设计研究生专业优化培训方式
  • 网站内做二级目录网站网络排名优化方法
  • 自己电脑做局域网网站服务器seo推广需要多少钱
  • iis 建设网站山西百度查关键词排名
  • 免费企业网站成人教育培训机构十大排名