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

天津市建设工程定额网站自己做网站在线看pdf

天津市建设工程定额网站,自己做网站在线看pdf,wordpress博客添加到菜单,网站放在服务器上文章目录 前置知识贪心算法的本质什么时候用贪心算法?什么时候不能用贪心?贪心算法的解题步骤 455.分发饼干题目描述解题思路代码 376. 摆动序列题目描述解题思路代码 53. 最大子序和题目描述暴力解法动态规划贪心算法 总结 前置知识 贪心算法的本质 贪心的本质是选择每一阶…

文章目录

  • 前置知识
    • 贪心算法的本质
    • 什么时候用贪心算法?
    • 什么时候不能用贪心?
    • 贪心算法的解题步骤
  • 455.分发饼干
    • 题目描述
    • 解题思路
    • 代码
  • 376. 摆动序列
    • 题目描述
    • 解题思路
    • 代码
  • 53. 最大子序和
    • 题目描述
    • 暴力解法
    • 动态规划
    • 贪心算法
  • 总结

前置知识

贪心算法的本质

贪心的本质是选择每一阶段的局部最优,从而达到全局最优。

例如,有一堆钞票,你可以拿走十张,如果想达到最大的金额,你要怎么拿?
指定每次拿最大的,最终结果就是拿走最大数额的钱。
每次拿最大的就是局部最优,最后拿走最大数额的钱就是推出全局最优。

什么时候用贪心算法?

  1. 感觉像是可以用贪心
  2. 用题中的案例试一下, 发现没问题
  3. 尝试举一下反例, 发现没问题
  4. 那就可以用了

所以贪心算法并没有固定的规律和套路, 也不会要求你论证背后算法的合理性和有效性, 只要能解决问题, 通过测试案例即可.

ps:个人认为贪心非常虚无缥缈呀, 还是动态规划更加有迹可循;
并且在实践过程中, 可以用贪心算法的, 基本都可以用动态规划.

什么时候不能用贪心?

当局部最优, 不一定可以达到全局最优的时候, 如:

有一堆盒子,你有一个背包体积为n,如何把背包尽可能装;
如果还每次选最大的盒子,就不行了。
这时候就需要动态规划。

贪心算法的解题步骤

  1. 将问题分解为若干个子问题
  2. 找出适合的贪心策略
  3. 求解每一个子问题的最优解
  4. 将局部最优解堆叠成全局最优解

这样的叙述非常抽象, 实践过程中还是要把握思想: 选择每一阶段的局部最优,从而达到全局最优

参考文章:关于贪心算法, 你该了解这些

455.分发饼干

题目描述

截图

LeetCode链接:https://leetcode.cn/problems/assign-cookies/description/

解题思路

思路: 先将两个数组都srot
遍历g数组, 优先满足胃口最小的孩子
遍历g数组中的元素gg的时候, 依次遍历s数组, 选择能满足gg的最小尺寸饼干

代码

class Solution {
public:int findContentChildren(vector<int>& g, vector<int>& s) {int ans=0;sort(g.begin(), g.end());sort(s.begin(), s.end());int ss=0;for(int gg : g){for(; ss<s.size(); ++ss){if(s[ss] >= gg){s[ss] = 0;ans++;break;}}}return ans;}
};

376. 摆动序列

题目描述

在这里插入图片描述

LeetCode链接:https://leetcode.cn/problems/wiggle-subsequence/description/

解题思路

<代>: 其实过程中不需要对数组进行操作, 只需要看有多少个点是符合要求的即可;
具体过程比较复杂, 建议参考其原文.

代码

class Solution {
public:int wiggleMaxLength(vector<int>& nums) {int n=nums.size();if(n==0 || n==1 || (n==2 && nums[0]!=nums[1]))return n;int curDiff = 0;int preDiff = 0;int ans=1;for(int i=0; i<n-1; ++i){curDiff = nums[i+1] - nums[i];if((preDiff<=0 && curDiff>0) || (preDiff>=0 && curDiff<0)){ans++;preDiff = curDiff;}}return ans;}
};

53. 最大子序和

题目描述

截图

LeetCode链接:https://leetcode.cn/problems/maximum-subarray/description/

暴力解法

思路: 暴力解法
对数组中每个数, 都依次向后遍历所有子数组, 求和, 和ansmax

class Solution {
public:int maxSubArray(vector<int>& nums) {int ans=INT_MIN;for(int i=0; i<nums.size(); ++i){int sum=0;for(int j=i; j<nums.size(); ++j){sum += nums[j];ans = max(ans, sum);}}return ans;}
};

动态规划

不出所料的, 超出时间限制;
用动态规划, 创建数组maxSum
nums[0]maxSum[0]就是自己本身
之后的nums[i]maxSum[i]=max(nums[i], maxSum[i-1]+nums[i])

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

优化: 不用数组用pre

class Solution {
public:int maxSubArray(vector<int>& nums) {int ans = nums[0];int pre = nums[0];for(int i=1; i<nums.size(); ++i){pre = max(pre+nums[i], nums[i]);ans = max(ans, pre);}return ans;}
};

贪心算法

在这里插入图片描述
选取一个个"区间", 过程中用count记录区间内的和;
count<0时, 将其清空(=0)

class Solution {
public:int maxSubArray(vector<int>& nums) {int ans = INT_MIN;int count=0;for(int i=0; i<nums.size(); ++i){count += nums[i];ans = max(ans, count);if(count<0)count = 0;}return ans;}
};

总结

相比于动态规划, 贪心算法的思路难把握的多, 也很难以揣摩;
所以过程中如果想不出来, 第一反应应该是尝试动态规划, 或者直接看题解;

一方面不要在做题过程中硬磕贪心算法;
另一方面在学习的时候, 不要过于较真, 对于贪心这一部分的内容, 可以适当抱着"了解"和:"探索学习"的心态.
把精力多花在可以比较快比较好地掌握和把握的部分和方法上.

本文参考:
分发饼干
摆动序列
最大子序和

http://www.yayakq.cn/news/431061/

相关文章:

  • 大学生做的美食网站公司网站后台管理
  • 做捕鱼网站电话建设网站的网络公司
  • 上饶门户网站建设腾讯短链接
  • 免费响应式企业网站源码网站建设saas
  • 有关网站建设国内外现状的文献网站模板在线制作
  • 集宁网站建设建网站免费吗
  • 网站里怎样做物流跟踪功能建设网站需要营业执照
  • wordpress首页html代码烟台seo网站诊断
  • 怎么用域名进网站seo网站文章编辑软件
  • 网站建设做什么培训班管理系统 免费
  • 大型网站建设机构在线设计平台的市场调研
  • 黄骅市网站建设价格三亚网站开发公司
  • 1717做网站wordpress 3306
  • 网站制作设计方案音乐自助建站
  • dj音乐网站建设开发北京定制网页
  • 县工商局 网站建设wordpress百度翻译
  • h5企业网站通用源码检察院门户网站建设自查自纠报告
  • 网站如何备案要关站吗开发软件属于什么行业
  • 深圳商城网站建设报价单企业网站模板psd
  • 做旅游的海报图片网站注册网站域名需要什么资料医疗器械
  • 可以上传网站的免费空间关于网站建设方案的案例
  • 潍坊高密网站建设即墨网站设计
  • 做网站的有哪些公司福州市市政建设开发有限公司网站
  • 普洱市住房和城乡建设局网站做网商必备网站
  • 网站开发实训基本要求做灯具网站推广哪家好
  • 做家乡网站代码最新采购求购信息网站
  • 山东省住房城乡建设厅门户网站商城网站开发费用一般是多少
  • 服务器什么建网站怎么用阿里的域名 做网站
  • 网站seo优化网站设计制作上海公司
  • 域名会影响网站排名吗网站添加搜索关键字