zoukankan      html  css  js  c++  java
  • 看电视(贪心算法)

    问题 A: 看电视

    时间限制: 1 Sec  内存限制: 32 MB
    提交: 927  解决: 432
    [提交][状态][讨论版][命题人:外部导入]

    题目描述

    暑假到了,小明终于可以开心的看电视了。但是小明喜欢的节目太多了,他希望尽量多的看到完整的节目。
    现在他把他喜欢的电视节目的转播时间表给你,你能帮他合理安排吗?

    输入

    输入包含多组测试数据。每组输入的第一行是一个整数n(n<=100),表示小明喜欢的节目的总数。
    接下来n行,每行输入两个整数si和ei(1<=i<=n),表示第i个节目的开始和结束时间,为了简化问题,每个时间都用一个正整数表示。
    当n=0时,输入结束。

    输出

    对于每组输入,输出能完整看到的电视节目的个数。

    样例输入

    12
    1 3
    3 4
    0 7
    3 8
    15 19
    15 20
    10 15
    8 18
    6 12
    5 10
    4 14
    2 9
    0

    样例输出

    5
    code:

    /*算法:使用贪心算法,时间按照开始时间从小到大的顺序排列,
    *如果开始时间相同,那么按照结束时间从小到大的顺序排列。之
    *后使用lastTV保留上一个最优解,如果下一个区间的开始时间大
    *于lastTV的结束时间,那么更新lastTV,直至所有区间被遍历完
    */
    #include <iostream>
    #include <algorithm>

    
    

    /*节目结构*/
    struct program {
    int si, ei;
    };
    program TV[1000];

    
    

    bool cmp(program a, program b) {
    if (a.ei != b.ei)
    {
    return a.ei < b.ei; //返回开始时间小的
    }
    else
    {
    return a.si < b.si; //返回结束时间小的
    }
    }
    int main()
    {
    using namespace std;

    
    

    int n;

    
    

    while (cin >> n)
    {
    if (!n)
    {
    break;
    }

    
    

    for (int i = 0; i < n; i++)
    {
    cin >> TV[i].si >> TV[i].ei;
    }

    
    

    /*根据开始时间从小到大排序,如果相等,那么结束时间小的在前*/
    sort(TV, TV + n, cmp);

    
    

    /*for (int i = 0; i < n; i++)
    {
    cout << TV[i].si <<" "<< TV[i].ei<<endl;
    }*/

    
    

    int lastTV = TV[0].ei, count = 1;
    //cout << lastTV<<endl;
    for (int i = 1; i < n; i++)
    {
    if (TV[i].si >= lastTV)
    {
    count++;
    lastTV = TV[i].ei;
    }
    }
    cout << count << endl;

    
    

    }

    
    

    // system("pause");
    return 0;
    }

     
  • 相关阅读:
    CentOS 7.3 系统安装配置图解教程
    图床神器:七牛云 + Mpic + FScapture
    Markdown 使用教程
    Python小游戏、小程序
    深入理解Python中的yield和send
    替代crontab,任务计划统一集中管理系统cronsun简介
    变量命名神器Codelf
    Spring Aspect实现AOP切面
    SpringCloud之注册中心Eureka搭建
    SpringCloud中eureka配置心跳和剔除下线的服务的时间
  • 原文地址:https://www.cnblogs.com/yangyalong/p/10610278.html
Copyright © 2011-2022 走看看