ACM第一次练习-1004

题目编号:E

简单题意:输入一天中要看的节目数n,输入n组节目的开始和结束时间(用整数表示),设计算法输出能完整看完的节目个数。输入数据有多组,当n=0是程序结束。

解题思路形成过程:要定义一个结构体来存放各个电视节目的开始和结束时间;用while循环输入,n==0循环结束;用vector来存放所有节目;sort函数将所有节目 排序(自定义排序原则:开始时间相同的先结束的在前);定义迭代器,累加器,用循环判断两节目前者的结束时间与后者开始时间是否冲突,不冲突则选中;输出累加器的值。

感想:1.使用vector向量容器可以带来很多便利,以后要慢慢适应用STL来解决问题。

            2.贪心算法的核心是贪心策略,但是前面的准备步骤也很重要,解决好前面,核心部分才能顺利解决。

            3.对定义和使用迭代器还要加深理解。

代码:

#include<algorithm>

#include<iostream>
#include<vector>
#include<fstream>
using namespace std;


struct time
{


int Ti_start;
int Ti_end;
bool b;
};


bool cmp(const time &a, const time &b)
{
return a.Ti_end <= b.Ti_end;
}


int main()
{
int n;
while (cin >> n)
{
if (n == 0)    break;
vector<time> tv(n);
vector<time>::iterator it1, it2;


for (int i = 0; i<n; i++)
{
cin >> tv[i].Ti_start;
cin >> tv[i].Ti_end;
tv[i].b = 0;
}


sort(tv.begin(), tv.end(), cmp);


it2 = tv.begin();
(*it2).b = 1;


int p = 1;
for (it1 = tv.begin() + 1; it1 != tv.end(); it1++)
{
if ((*it2).b = 1 && (*it1).Ti_start >= (*it2).Ti_end)
{
(*it1).b = 1;
it2 = it1;
p++;
}
}
cout << p << endl;
}
}

你可能感兴趣的:(ACM)