牛客算法入门(第二课,课后题,栈和排序,难度2星)

牛客算法入门(第二课,课后题,栈和排序,难度2星)

题目链接:https://ac.nowcoder.com/acm/problem/14893

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 131072K,其他语言262144K
64bit IO Format: %lld

题目描述

给你一个1->n的排列和一个栈,入栈顺序给定

你要在不打乱入栈顺序的情况下,对数组进行从大到小排序

当无法完全排序时,请输出字典序最大的出栈序列

输入描述:

第一行一个数n
第二行n个数,表示入栈的顺序,用空格隔开,结尾无空格

输出描述:

输出一行n个数表示答案,用空格隔开,结尾无空格

示例1

输入

5
2 1 5 3 4

输出

5 4 3 1 2

说明

2入栈;1入栈;5入栈;5出栈;3入栈;4入栈;4出栈;3出栈;1出栈;2出栈

读入数据

第i个数出栈满足字典序最大,一定是i+1到n中最大的一个数

用一个数组maxs存i-n之间最大的数

按照读入顺序入栈,如果当前入栈第i个数字比将要入栈的剩余元素都要大 那么这个元素出栈

因为让入栈的第i个元素,比将要入栈的i+1到n的元素都大时出栈,总能保证字典序最大


import java.util.Scanner;
public class 栈和排序 {
    static int n;
    static int max;
    static  int[] stack;
    static int[] maxs;
    static int[] arr;
     static int top=-1;
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        n=sc.nextInt();
        stack=new int[n];
        maxs=new int[n*2];
        arr=new int[n];
        for (int i = 0; i <n; i++) {
           arr[i]=sc.nextInt();
        }

        //找出i到n中最大的那个值
        for (int i = n-1; i>=0; i--) {
            max=Math.max(max,arr[i]);
            maxs[i]=max;
        }

        for (int i = 0; i <n; i++) {
            //入栈
            stack[++top]=arr[i];
            //如果当前入栈的值 大于i+1到n之间的最大值 那么出栈
            //maxs[i+1]最后一定为0,所有栈内元素可以全部出栈
            while (top>=0&&stack[top]>maxs[i+1]){
                System.out.print(stack[top]+" ");
                //模拟弹出栈顶,指针下移
                top--;
            }
        }

    }
}

你可能感兴趣的:(算法,java,数据结构)