列车调度问题[通俗易懂]

列车调度问题[通俗易懂]题目:高铁货运站的调配问题我们国家大力发展道路交通基础设施,最近这些年修建了大量的高铁线路,以促进国内的物资运输和调配,ZZ是一个超级货运站,是连接亚欧货运的枢纽站,现在ZZ货运站列车调度铁轨的结构如下图所示。两端分别是一条入口(Entrance)轨道和一条出口(Exit)轨道,它们之间有N条平行的轨道。每趟列车从入口可以选择任意…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

题目:高铁货运站的调配问题

我们国家大力发展道路交通基础设施,最近这些年修建了大量的高铁线路,以促进国内的物资运输和调配,ZZ是一个超级货运站,是连接亚欧货运的枢纽站,现在ZZ货运站列车调度铁轨的结构如下图所示。

 

                                                                             列车调度问题[通俗易懂]

 

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

【输入格式】:

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

【输出格式】:

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

【输入样例】:

9

8 4 2 5 3 9 1 6 7

【输出样例】:

4

1)题目分析: 此题为 ‘’求最少下降序列个数‘’的问题

要让列车降序输出,每一条轨道上必须编号大的先进入,编号小的后进入,所以每一条轨道上的列车是下降序列。如果待处理的列车编号比一条轨道上的最小编号要大,那么就要新开一条轨道让该车进入。

如果输入的列车编号是一个上升序列,那么需要的轨道条数就等于上升序列的个数。

样例中:

各条轨道应为:

————————————8 4 2 1

————————————5 3

————————————9 6

————————————7

2)解题方法思路:

a[i] 存储第i 下降序列 末尾的最小值

二分法:快速查找与待处理元素最相近的 下降序列 末尾元素,并更新元素

3)代码:

#include<stdio.h>
#include<stdlib.h>

int a[100001]; //存储每条轨道最后的数 

int main(){
	int n,m; //n为输入的数据个数,m做临时存储 
	int k=1; //k为轨道数,并初始化为1 
	scanf("%d\n",&n);
	scanf("%d",&m);
	a[1]=m;//初始化a[1] 
	for(int i = 1;i < n; i++){
		scanf("%d",&m);
		if(m>a[k]){//比a中最大数还大,就增加一条轨道 
			k++;
			a[k] = m;
		}
	
		else{ //二分法查找到a中与m最相近的值,然后更新那条轨道上的末尾的数 
			int l = 1;
			int r = k;
			
			while(l<=r){
				int mid = (l+r)/2;
				if(m>=a[mid]){
					l++;
				}
				else{
					r--;
				}
			}
			a[l] = m;
		}
		
	}
		
	printf("%d",k); //打印轨道数k 
	
}

 

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java calendar获取年_Java Calendar获取年、月、日、时间,设置年、月、日

    java calendar获取年_Java Calendar获取年、月、日、时间,设置年、月、日JavaCalendar获取年、月、日、时间Calendarc=Calendar.getInstance(TimeZone.getTimeZone(“GMT+08:00”));//获取东八区时间intyear=c.get(Calendar.YEAR);//获取年intmonth=c.get(Calendar.MONTH)+1;//获取月份,0表示1月份intday=c.get(Calendar.DAY_OF_MONTH);//获取当前

    2022年5月18日
    47
  • 剖析PetShop 4

    剖析PetShop 4PetShop的系统架构设计前言:PetShop是一个范例,微软用它来展示.Net企业系统开发的能力。业界有许多.Net与J2EE之争,许多数据是从微软的PetShop和Sun的PetStore而来。这种争论不可避免带有浓厚的商业色彩,对于我们开发人员而言,没有必要过多关注。然而PetShop随着版本的不断更新,至现在基于.Net2.0的PetShop4.0为止,整个设计逐渐变得成熟而优雅,

    2022年10月17日
    2
  • CMPP讲解_cmpp2.0

    CMPP讲解_cmpp2.0  1 、缩略语解释  ISMG                         InternetShortMessageGateway     互联网短信网关

    2025年8月1日
    6
  • JavaScript详细解析

    JavaScript详细解析文章目录1、JavaScript详细解析1.1、JavaScript介绍1.2、快速入门引入js的方式一:内部方式引入js的方式一:外部方式1.3、开发环境搭建1.4、快速入门总结2、JavaScript基本语法2.1、注释2.2、输入输出语句2.3、变量和常量2.4、原始数据类型和typeof方法2.4.1、原始数据类型2.4.2、typeof2.5、运算符2.6、流程控制和循环语句2.7、数组2.8、函数2.9、小结3、JavaScriptDOM3.1、DOM介绍3.2、Element元素的获取操作3

    2022年7月17日
    13
  • python常用函数总结

    python常用函数总结普通函数一、输入输出函数1、print()函数输出函数向屏幕输出指定的汉字print("helloworld")print()函数可以同时输出多个字符串,用逗号“,”

    2022年7月5日
    23
  • 查看JAVA API以及JAVA源码的方法

    查看JAVA API以及JAVA源码的方法在java的日常学习中,我们有时候会需要看java的api说明,或者是查看java的源码,使我们更好的了解java,接下来我就来说说如何查看java的api以及java源码对于java的api,一般是在下面的网址中进行查看https://docs.oracle.com/javase/8/docs/api/而对于java的源码,我们现在来演示查看nextLine()的源码:将鼠标…

    2022年7月26日
    2

发表回复

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

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