笔试——环形公交

有一环形公交站,包含N(N>=3)个站点{站点序号为:1~N},每个站点停留5分钟,相邻两个站点之间行驶时间都是10分钟,循环形式,已知第一圈第一个站点进入时间为X,现在公交形式时间为Y,请计算当前公交圈数,以及处在哪个站点之间M-N(如果停在某个站点Z,则输出Z-Z)

输入:

一行字符串:3,2017-07-25 06:00:00,2017-07-25 06:40:00【整数、时间字符串、时间字符串】时间精确到分钟,分别表示站点数,第一圈第一个站点的进入时间、目前时间;数据之间使用逗号分隔;要求至少三个站点。如输入条件不满足,则输出“incorrect data”

输出:

1;1-2

数据表示:公交正在行驶第一圈,在第一个和第二个站点之间;圈数与行驶站点之间使用分号分隔。

如果是1;2-2,则表示公交正在行驶第一圈,停留在第二个站点。


样例输入:

3,2017-07-25 06:00:00,2017-07-25 06:40:00

3,2017-07-25 06:00:00,2017-07-25 08:45:00

1,2017-07-25 06:00:00,2017-07-25 06:40:00

3,2017-07-25 06:00:66,2017-07-25 06:40:99

样例输出:

1;3-1

4;3-3

incorrect data

1;3-1


代码如下:

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner;

public class BusTime {
	
	public static void main(String[] args) {
		Scanner s = new Scanner(System.in);
		String[] ss = s.nextLine().split(",");
//		String[] ss = "3,2017-07-25 06:00:00,2017-07-25 06:40:00".split(",");
		int n = Integer.valueOf(ss[0]);
		
		Date date_start=null;
		Date date_end=null;
		
		DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
		
		try {
			date_start = format.parse(ss[1]);
			date_end = format.parse(ss[2]);
		} catch (ParseException e) {
			e.printStackTrace();
		}
		
		long min = (date_end.getTime()-date_start.getTime())/(1000*60);	//得到间隔的分钟数

		if(n<3 || min<0){
			System.out.println("incorrect data");
			return;
		}
		
		long q_Num = min / (15 * n);	//圈数
		
		long le_min = min % (15 * n);	//q_Num圈之后剩余的分钟数
//		System.out.println(le_min);
		
		long a = le_min / 15;	//剩余多少分钟所走的战术
		long b = le_min % 15;	//经过最后一个站点之后的剩余
//		System.out.println(a +"***"+b);
		
		System.out.print((q_Num+1)+";");
		
		if(b>=0 && b<=5){
			System.out.println((a%n+1)+"-"+(a%n+1));
		}else{
			System.out.println((a%n+1)+"-"+(a%n+2)%n);
		}
		
	}
	
}

通过90%,不知道是不是秒级单位的影响,但是最后一个样例有66s和99s。但是仍然正确,不知道是什么原因,望大神指点



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你好!对于成都笔试中的PL/SQL准备,我可以为你提供一些指导和建议。PL/SQL是一种过程式编程语言,用于Oracle数据库的开发和管理。下面是一些可以帮助你准备PL/SQL笔试的建议: 1. 理解PL/SQL语法:掌握PL/SQL的基本语法结构,包括变量声明、条件语句、循环语句、游标和异常处理等。熟悉这些基础知识对于理解和编写PL/SQL代码至关重要。 2. 学习SQL语句:PL/SQL是建立在SQL语言基础上的,所以熟悉SQL语句也是非常重要的。掌握SQL查询、插入、更新和删除等基本操作,以及表连接、子查询和聚合函数等高级查询技巧。 3. 理解存储过程和函数:PL/SQL的核心概念是存储过程和函数。了解它们的定义、调用和使用方法,以及参数传递、返回值和异常处理等方面的知识。 4. 掌握PL/SQL的高级特性:学习PL/SQL的高级特性,如游标、触发器和包等。了解它们的用途和使用方法,以及与数据库交互和数据处理的相关技巧。 5. 多做练习题和项目实践:通过做一些练习题和实际项目,加深对PL/SQL的理解和应用能力。可以使用在线编程平台或者自己搭建一个本地的Oracle数据库环境。 6. 阅读相关文档和教程:阅读Oracle官方文档和一些相关的教程和书籍,可以帮助你更全面地了解和掌握PL/SQL的知识。 希望以上建议对你有所帮助!祝你在成都笔试中取得好成绩!如果你还有其他问题,可以继续向我提问。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值