智能红绿灯

科技公司在养老社区设置了一款智能红绿灯,其特点是当无人按下按钮时保持绿灯,老年人需要过马路时按下按钮,15秒后绿灯转红,红灯亮30秒。在红灯期间再次按下按钮可延长15秒红灯时间。程序需根据给定的按钮按下时间点计算并输出红灯时间区间。
摘要由CSDN通过智能技术生成

智能红绿灯

为了最大化通行效率同时照顾老年人穿行马路,在某养老社区前,某科技公司设置了一个智能红绿灯。

这个红绿灯是这样设计的:

路的两旁设置了一个按钮,老年人希望通行马路时会按下按钮;

在没有人按按钮的时候,红绿灯一直为绿灯;

当红绿灯为绿灯时,有人按下按钮,第一次按下按钮的 15 秒后绿灯会转红;

转红后,红灯会持续 30 秒,方便老年人穿行马路;

在 30 秒的红灯期间,假如有人再次按下按钮,则红灯会再延续 15 秒;

延续一次后不会再次延续。

现在给定按钮被按下的时间点,请你输出这个智能红绿灯的红灯时间区间。

注意:我们假设同一秒内,红绿灯先变化,然后按钮再被按下。每 1 秒理解为一个时间点。例如:在第 1 秒按下按钮,则第 16 秒开始变红;如果没有人在第 16 - 45 秒这个闭区间内按下按钮,则到第 46 秒开始变绿。而在第 46 秒按下按钮的人,需要等 15 秒后才有红灯。

输入格式:

输入第一行为 N (1≤N≤1000),表示按钮被按下的次数。

接下来一行 N 个非负整数,表示按钮被按下的时间点。一个时间点按钮有可能会被多次按下,给出的时间点保证是不递减的。

时间点的范围不超过 10^4。

输出格式:

输出若干行,按起始时间从小到大输出互不相交的红灯的时间区间。

输入样例:

在这里给出一组输入。例如:

10
3 4 5 6 33 45 49 70 90 100

输出样例:

在这里给出相应的输出。例如:

18 62
85 129
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int n = scan.nextInt();
        int[] arr = new int[n];
        for (int i = 0; i < n; i++) {
            arr[i] = scan.nextInt();
        }
        int begin = 0;
        int end = 0;
        for (int i = 0; i < n; i++) {
            if (arr[i] >= begin) {
                begin = arr[i] + 15;
                end = begin + 29;
                for (int j = 0; j < n; j++) {
                    if (arr[j] >= begin && arr[j] <= end) {
                        end += 15;
                        System.out.println(begin + " " + end);
                        begin = end;
                        break;
                    }
                }
            }
        }
    }
}

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值