##L2-014 列车调度 (25 分)
题意
思路
1.根据题意是让火车以递减顺序排列,那么如果不能按这个顺序排列的的车就要排在轨道中,末尾最后的火车编号比需要加入的火车大,如果小就需要新加个轨道
代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
int a[N],b[N];//a存放原来火车的顺序,b记录轨道内最后一辆车的编号
int main()
{
int n;
cin>>n;
int cnt=0;//记录轨道数
for(int i=0;i<n;i++)
{
cin>>a[i];
if(cnt==0||b[cnt-1]<a[i])//如果轨道数为0或轨道内末尾最后的火车编号比需要加入的火车小,需要新加个轨道
{
b[cnt++]=a[i];
}
else
{
int l=0,r=cnt-1;//找到间距最小的轨道加入
while(l<r)
{
int mid=(l+r)/2;
if(b[mid]>a[i])
{
r=mid;
}
else
{
l=mid+1;
}
}
b[l]=a[i];
}
}
cout<<cnt;
return 0;
}