版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Hacker_Wind/article/details/81812830
问题 A: 看电视
时间限制: 1 Sec 内存限制: 32 MB
提交: 420 解决: 222
[提交][状态][讨论版][命题人:外部导入]
题目描述
暑假到了,小明终于可以开心的看电视了。但是小明喜欢的节目太多了,他希望尽量多的看到完整的节目。
现在他把他喜欢的电视节目的转播时间表给你,你能帮他合理安排吗?
输入
输入包含多组测试数据。每组输入的第一行是一个整数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
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <queue>
#include <stack>
#include <set>
#include <iomanip>
using namespace std;
struct tv
{
int s;
int e;
}t[105];
bool cmp(tv a,tv b)
{
if(a.s==b.s)
return a.e<b.e;
return a.s>b.s;
}
int main()
{
int n;
while(cin>>n&&n)
{
for(int i=0;i<n;i++)
{
cin>>t[i].s>>t[i].e;
}
sort(t,t+n,cmp);
int lastx=t[0].s;
int ans=1;
for(int i=1;i<n;i++)
{
if(t[i].e<=lastx)
{
lastx=t[i].s;
ans++;
}
}
cout<<ans<<endl;
}
return 0;
}