列车调度(PTA)

列车调度(PTA)7-11列车调度(25分)火车站的列车调度铁轨的结构如下图所示。两端分别是一条入口(Entrance)轨道和一条出口(Exit)轨道,它们之间有N条平行的轨道。每趟列车从入口可以选择任意一条

大家好,又见面了,我是你们的朋友全栈君。

7-11 列车调度 (25 分)

火车站的列车调度铁轨的结构如下图所示。

<span role="heading" aria-level="2">列车调度(PTA)

两端分别是一条入口(Entrance)轨道和一条出口(Exit)轨道,它们之间有N条平行的轨道。每趟列车从入口可以选择任意一条轨道进入,最后从出口离开。在图中有9趟列车,在入口处按照{8,4,2,5,3,9,1,6,7}的顺序排队等待进入。如果要求它们必须按序号递减的顺序从出口离开,则至少需要多少条平行铁轨用于调度?

输入格式:

输入第一行给出一个整数N (2 N 105​​),下一行给出从1到N的整数序号的一个重排列。数字间以空格分隔。

输出格式:

在一行中输出可以将输入的列车按序号递减的顺序调离所需要的最少的铁轨条数。

输入样例:

9
8 4 2 5 3 9 1 6 7

输出样例:

4

一维数组 + 二分查找

一维数组模拟各轨道,数组记录当前轨道最小的数,设置全轨道最大值maxn
大于maxn说明当前各个轨道都容不下,轨道数+1,否则二分查找大于当前值的最小数,更新

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <algorithm>
 5 using namespace std;
 6 
 7 int main()
 8 {
 9     const int N=1e5+5;
10     int tear[N];
11     memset(tear,0,sizeof(tear));
12     int n,x,cnt=0,maxn=0;
13 
14     scanf("%d",&n);
15     for(int i=0;i<n;i++){
16         scanf("%d",&x);
17         if(x>maxn){
18             tear[cnt++]=maxn=x;
19             continue;
20         }
21         //二分查找
22         int l=0,r=cnt;
23         while(l!=r){
24             if(tear[(l+r)/2]<x){
25                 l=(l+r)/2+1;
26             }
27             else{
28                 r=(l+r)/2;
29             }
30         }
31         tear[l]=x;
32         if(l==cnt-1){
33             maxn=x;
34         }
35     }
36     cout<<cnt<<endl;
37     return 0;
38 }

 


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154573.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月1日 下午6:16
下一篇 2022年7月1日 下午6:16


相关推荐

  • linux下安装mysql-5.7.25详细步骤

    linux下安装mysql-5.7.25详细步骤第一步:下载进入到mysql官网下载自己对应版本的mysql,下载地址:https://dev.mysql.com/downloads/mysql/5.7.html#downloads我这里下载mysql-5.7.25-linux-glibc2.12-x86_64.tar.gz版本也可以进入linux后用命令下载wgethttps://cdn.mysql.com/…

    2022年6月12日
    43
  • 面向对象编程(Python版详解)

    面向对象编程(Python版详解)本篇是面向对象编程 Python 版详解 案例教学超详细 欢迎打卡 阅读学习

    2026年3月19日
    2
  • 时间序列的聚类方法

    时间序列的聚类方法时间序列的聚类方法时间序列是按照时间排序的一组随机变量 它通常是在相等间隔的时间段内 依照给定的采样率 对某种潜在过程进行观测的结果 时间序列数据是实值型的序列数据 具有数据量大 数据维度高以及数据是不断更新的等特点 时间序列聚类方法的分类什么是聚类 聚类是一种无监督学习方法 聚类就是按照某个特定标准 如距离 把一个数据集分割成不同的类或簇 使类内差异最小 类间差异最大 传统的聚类方法针对

    2026年3月26日
    1
  • 【电赛】2017年电赛A题——三相逆变电源EG8030测试

    【电赛】2017年电赛A题——三相逆变电源EG8030测试目录:一、相关介绍1.创建窗口【Tk】2.创建标签【Label】3.创建按钮【Button】二、简易滚动抽奖界面代码三、界面展示注:本文仅用于学习交流分享,[若有不妥之处,请指正,感谢]关键词:【电赛】【三项逆变电源】【EG8030】用到的工具有:AltiumDesigner16.0实现的功能有:①实现三相SPWM②实现三相交流电一、相关介绍SPWM:脉冲宽度按正…

    2022年5月5日
    117
  • linux 查看磁盘空间大小

    linux 查看磁盘空间大小

    2021年11月9日
    49
  • 移动端SEO优化指南:让手机用户找到你的15个技巧

    移动端SEO优化指南:让手机用户找到你的15个技巧

    2026年3月18日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号