题目背景: 那一年,这一年,青春散场,到毕业季,我们奔波着忙着找工作,来到招聘会上,看到黑压压的一大片人群.. 题目描述:毕业季,很多大公司来学校招聘,招聘会分散在不同时间段,小明想知道自己最多能完整的参加多少个招聘会(参加一个招聘会的时候不能中断或离开)。 假设现在有n个招聘会,每个招聘会都有个起止时间,时间由从招聘会第一天0点开始的小时数表示,n <= 1000 。 返回:最多参加的招聘会的个数n。 举个例子: 现在有3场招聘会,他们的起始时间为: 9-10 10-20 8-15 返回:2
典型的贪心算法:对结束时间排序,再遍历:
#include <cmath>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
#include <utility>
using namespace std;
int forjob(vector<pair<int,int> > &time);
bool cmp(pair<int,int> a,pair<int,int> b){
return a.second<b.second;
}
bool iscomp(pair<int,int> a,pair<int,int> b){
if(b.first>=a.second)return true;
else return false;
}
int main()
{
vector<pair<int,int> >time;
//pair<int,int> a;
time.push_back(make_pair(9,10));
time.push_back(make_pair(10,20));
time.push_back(make_pair(8,15));
sort(time.begin(),time.end(),cmp);
cout<<forjob(time)<<endl;
return 0;
}
int forjob(vector<pair<int,int> > &time)
{
int num=1;
vector<pair<int,int> >::size_type j=0;
for(vector<pair<int,int> >::size_type i=1;i!=time.size();i++)
{
if(iscomp(time[j],time[i])){num++;j=i;}
}
return num;
}