码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 贪心算法求解活动选择问题


    问题描述:

       有一个需要使用每个资源的n个活动组成的集合S= {a1,a2,···,an },资源每次只能由一个活动使用。每个活动a都有一个开始时间和结束时间,且 0<= s < f 。一旦被选择后,活动a就占据半开时间区间[s,f]。如果[si,fi]和[sj,fj]互不重叠,则称两个ai,aj活动是兼容的。该问题就是要找出一个由互相兼容的活动组成的最大子集.假设输入的活动集合S已经按照结束时间的单调递增顺寻进行了排序.

    i1234567891011
    si130535688212
    fi4567891011121314

    求解思路:

      贪心算法的主要思想就是对问题求解时,总是做出在当前看来是最好的选择,产生一个局部最优解。

      在活动选择问题中,每次的贪心解就是选择Sij结束时间最早的活动,这样就给后面的活动留下了目前看来最多的时间。假设活动已经按照结束时间递增的顺序进行排序,那么我们只需要遍历一次所有活动就可以得到最大兼容活动子集了。

      

     ************************************************************************/
    #include
    
    #define MAX 11
    
    int s[MAX] = {1, 3, 0, 5, 3, 5, 6, 8, 8, 2, 12};
    int f[MAX] = {4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14};
    
    void GreedyActivitySelector(int st, int fi)
    {
        int m, i;
    
        i = st;
        printf("a%d ", i+1);
        
        for (m=i+1; m < fi; m++)
        {
            if (s[m] >= f[i])
            {
                printf("a%d ", m+1);
                i = m;
            }
        }
        
        printf("\n");
    }
    
    int main()
    {
        GreedyActivitySelector(0, MAX);
    
        return 0;
    }
  • 相关阅读:
    Apipost使用介绍
    异步代码执行顺序
    Oracle根据逗号拆分字段内容转成多行
    【VCSA 8】安装vCenter Server Appliance(VCSA) 8.0
    交换机与路由器技术-02-以太网交换机工作原理
    Flutter调用以太坊区块链智能合约 (私链)
    Python学习----函数
    第3章 helloworld 驱动实验(iTOP-RK3568开发板驱动开发指南 )
    动手写prometheus的exporter-03-HIstogram(直方图)
    顺序表详解(SeqList)
  • 原文地址:https://blog.csdn.net/cqn2bd2b/article/details/127995386
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号