贪心算法(四)

目录

一、分发饼干

二、最优除法

三、跳跃游戏II

四、跳跃游戏

五、加油站


一、分发饼干

分发饼干

贪心策略:

1、首先,对 g 数组和 s 数组进行排序。

2、对两个数组从前往后同时进行遍历:

~ 如果 g[p1] <= s[p2],说明相应位置的饼干能够满足对应位置的孩子的胃口,满足的孩子数加1。那么我们就去找下一个饼干能否满足下一个孩子。

~ 如果 g[p1] > s[p2],说明相应位置的饼干不能够满足对应位置的孩子的胃口。那么该饼干更不可能满足该孩子之后的孩子了,所以直接忽略掉这块饼干,去看下一块饼干能否满足这个孩子。

解题代码:

cpp 复制代码
class Solution 
{
public:
    int findContentChildren(vector<int>& g, vector<int>& s) 
    {
        sort(g.begin(), g.end());
        sort(s.begin(), s.end());

        int p1 = 0, p2 = 0;
        int ret = 0;
        while(p1 < g.size() && p2 < s.size())
        {
            if(g[p1] <= s[p2])
            {
                ret++;
                p1++;
                p2++;
            }
            else
                p2++;
        }
        return ret;
    }
};

二、最优除法

最优除法

贪心策略:

这道题的贪心策略很简单。直接在第一个 ' / ' 后面加 ' ( ',然后在最后添加 ' ) ',就完成了括号的添加。此时得到的结果就是最大值。

解题代码:

cpp 复制代码
class Solution 
{
public:
    string optimalDivision(vector<int>& nums) 
    {
        int n = nums.size();
        if(n == 1)
            return to_string(nums[0]);

        if(n == 2)
            return to_string(nums[0]) + '/' + to_string(nums[1]);

        string ret = to_string(nums[0]) + '/' + '(' + to_string(nums[1]);
        for(int i = 2; i < n; i++)
            ret += '/' + to_string(nums[i]);

        ret += ')';
        return ret;   
    }
};

三、跳跃游戏II

跳跃游戏II

贪心策略:

根据上图,我们可以分析:从棕色方框位置起跳,可以到达红色方框中的某一个数;从红色方框位置的某一个数起跳,可以到达黄色方框的某一个数; 从黄色方框位置的某一个数起跳,可以到达绿色方框的某一个数。

从棕色方框起跳到红色方框,再从红色方框跳到黄色方框,最后从黄色方框跳动绿色方框。一共跳了3次。所以说只需要三次我们就可以跳到数组末尾。

其实,这个方法有点像树的层序遍历,也就是一层一层地向后扩展。

解题代码:

cpp 复制代码
class Solution 
{
public:
    int jump(vector<int>& nums) 
    {
        int m = nums.size();
        int left = 0, right = 0, maxpos = 0;
        int ret = 0;
        while(left <= right)
        {
            if(maxpos >= m-1)
                return ret;

            for(int i = left; i <= right; i++)
                maxpos = max(maxpos, nums[i]+i);

            left = right+1;
            right = maxpos;
            ret++;
        }
        return -1;
    }
};

四、跳跃游戏

跳跃游戏

贪心策略:

这道题的贪心策略和上一道题,跳跃游戏II 的贪心策略一模一样,只是题目要求的返回结果不一样。

解题代码:

cpp 复制代码
class Solution 
{
public:
    bool canJump(vector<int>& nums) 
    {
        int left = 0, right = 0, maxpos = INT_MIN;
        while(left <= right)
        {
            for(int i = left; i <= right; i++)
                maxpos = max(maxpos, nums[i]+i);

            if(maxpos >= nums.size()-1)
                return true;
            
            left = right + 1;
            right = maxpos;
        }

        return false;
    }
};

五、加油站

加油站

暴力解法:依次枚举数组的每一个起点,看看能不能从该起点出发,然后回到起点。

于是,我们写出了如下的代码,提交后超出了时间限制。

贪心策略:

因为暴力解法超出了时间限制,所以我们必须要想出一个优化方法。

解题代码:

cpp 复制代码
class Solution 
{
public:
    int canCompleteCircuit(vector<int>& gas, vector<int>& cost) 
    {
        int n = gas.size();
        for(int i = 0; i < n; i++) // 枚举某一个起点
        {
            int ret = 0;
            int step = 0;
            for( ; step < n; step++)
            {
                int index = (i + step) % n;
                ret += gas[index] - cost[index];
                if(ret < 0)
                    break;
            }

            if(ret >= 0)
                return i;
            
            i = i + step;
        }
        return -1;
    }
};
相关推荐
星河耀银海3 小时前
人工智能从入门到精通:机器学习基础算法实战与应用
人工智能·算法·机器学习
nice_lcj5203 小时前
数据结构之堆:从概念到应用全解析(附TOP-K经典问题)
java·数据结构·算法
无言(* ̄(エ) ̄)3 小时前
进程---Linux/C语言
java·开发语言·算法
漫随流水3 小时前
leetcode算法(429.N叉树的层序遍历)
数据结构·算法·leetcode·二叉树
漫随流水3 小时前
leetcode算法(116.填充每个节点的下一个右侧节点指针)
数据结构·算法·leetcode·二叉树
_OP_CHEN3 小时前
【算法基础篇】(四十四)数论之欧拉定理与扩展欧拉定理深度解析:从降幂到超大规模幂运算
c++·算法·蓝桥杯·算法竞赛·欧拉定理·扩展欧拉定理·acm/icpc
lfwh3 小时前
Java 中基于 DBSCAN 算法的车辆交汇点计算实现详解
java·开发语言·算法
数据大魔方3 小时前
【期货量化入门】期权交易入门:从零开始学期权量化(TqSdk完整教程)
数据库·python·mysql·算法·区块链·程序员创富
期货资管源码3 小时前
期货资管分仓软件开发/平台搭建经验分享
经验分享·算法·eclipse·区块链
Xの哲學4 小时前
Linux 实时调度机制深度解析
linux·服务器·网络·算法·边缘计算