c/c++算法之贪心与DP

题目背景: 那一年,这一年,青春散场,到毕业季,我们奔波着忙着找工作,来到招聘会上,看到黑压压的一大片人群.. 题目描述:毕业季,很多大公司来学校招聘,招聘会分散在不同时间段,小明想知道自己最多能完整的参加多少个招聘会(参加一个招聘会的时候不能中断或离开)。 假设现在有n个招聘会,每个招聘会都有个起止时间,时间由从招聘会第一天0点开始的小时数表示,n <= 1000 。 返回:最多参加的招聘会的个数n。 举个例子: 现在有3场招聘会,他们的起始时间为: 9-10 10-20 8-15 返回:2

这是英雄会的一个挑战题

下面是个人的实现方法,仅供参考,如有bug或者意见欢迎提出,共同交流

#include <cmath>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;

bool cmp(const pair<int,int> &tmpa,const pair<int,int> &tmpb )
{
   if (tmpa.second<tmpb.second)
   {
	   return 1;
   }
   else if (tmpa.second==tmpb.second)
   { 
	   if (tmpa.first<tmpb.first)
	   {
		   return	1;
	   }
	   else
		   return false;
   }
  else
	   return 0;


//	return tmpa.second<tmpb.second;
}
int forjob(vector<pair<int,int> > &time) 
{
       sort(time.begin(),time.end(),cmp);
	//返回能参加的招聘个数的数值n
	   int countNum=0;
	   int endNum=-1;
	   int SizeNum=time.size();
	   for (int i=0;i<SizeNum;i++)
	   {
		   if (endNum<=time[i].first)
	   {
		   endNum=time[i].second;
		   countNum++;
	   }

	   }

return countNum;
}


bool operator<(const pair<int,int> &tmpa,const pair<int,int> &tmpb)
{
	if (tmpa.second<tmpb.second)
	{
		return true;
	}
	else if (tmpa.second==tmpb.second)
	{ 
		if (tmpa.first<tmpb.first)
		{
			return true;
		}
	}
	else
		return false;
}
int _tmain(int argc, _TCHAR* argv[])
{
	vector<pair<int,int> > TimePair;
	pair<int,int> num1(2,8);
	pair<int,int> num2(3,4);
	pair<int,int> num3(2,5);
	pair<int,int> num4(5,8);
	pair<int,int> num5(8,20);
	TimePair.push_back(num4);
    TimePair.push_back(num1);
	TimePair.push_back(num2);
	TimePair.push_back(num3);
	TimePair.push_back(num5);
	int Num=forjob(TimePair);
cout<<Num<<endl;
	return 0;
}


 

斐讯N1是一款基于Amlogic S905D芯片的开发板,它原本运行的是Android操作系统。如果你想刷Ubuntu系统斐讯N1上,可以按照以下步骤进行操作: 1. 准备所需材料: - 一个TF卡读卡器 - 一个TF卡(建议容量大于8GB) 2. 下载并安装刷机工具: - 下载并安装Amlogic USB Burning Tool(刷机工具)到你的电脑上。 3. 下载Ubuntu系统镜像: - 在Ubuntu官方网站或其他可信的镜像站点上下载适用于Amlogic S905D芯片的Ubuntu系统镜像文件。 4. 刷写Ubuntu系统到TF卡: - 使用TF卡读卡器将TF卡连接到电脑上。 - 打开Amlogic USB Burning Tool,并选择你下载的Ubuntu系统镜像文件。 - 在刷机工具中选择"Start"开始刷写过程,等待刷写完成。 5. 连接斐讯N1和电脑: - 将USB转TTL串口线的USB端连接到电脑上,将串口端连接到斐讯N1的串口接口上。 6. 进入刷机模式: - 按住斐讯N1的复位按钮,然后插入TF卡。 - 斐讯N1会进入刷机模式,此时可以松开复位按钮。 7. 刷写Ubuntu系统斐讯N1: - 在刷机工具中点击"Connect"按钮,连接到斐讯N1。 - 点击"Start"开始刷写Ubuntu系统斐讯N1的内部存储器。 - 等待刷写完成后,断开USB转TTL串口线的连接。 8. 启动斐讯N1: - 拔掉TF卡,重新插入斐讯N1的电源线。 - 斐讯N1会自动启动,并进入刚刚刷写的Ubuntu系统。 请注意,刷写操作可能会有一定的风险,请谨慎操作并备份重要数据。另外,刷写非官方系统可能会违反设备的保修条款,请自行承担风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值