NC栈和排序

系列文章目录


文章目录


前言

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。


描述

给你一个 1 到 n 的排列和一个栈,并按照排列顺序入栈

你要在不打乱入栈顺序的情况下,仅利用入栈和出栈两种操作,输出字典序最大的出栈序列

排列:指 1 到 n 每个数字出现且仅出现一次

java 复制代码
import java.util.*;


public class Solution {
    /**
     * 栈排序
     * @param a int整型一维数组 描述入栈顺序
     * @return int整型一维数组
     */
    public int[] solve (int[] a) {
        // write code here
        Stack<integer> s = new Stack&lt;&gt;();//定义一个栈用来存储数据
        int n = a.length;
        int []res = new int[n];//用来返回结果
        int cnt = 0;
        boolean []vis = new boolean[n+10];//用来标记哪个数字出现过
        for(int i =0;i &lt; a.length;i ++){//遍历数组
            s.push(a[i]);//压入栈
            vis[a[i]] = true;//压入一个数就把对应的数字标记为true
            while(n&gt;0&amp;&amp; vis[n]) n--;//检测现有栈中有多少个数出现了就是较大的哪些数出现了(从大到小)
            while(!s.empty() &amp;&amp; n &lt;= s.peek()){
                //然后将栈中&gt;=n的元素出栈
                res[cnt ++] = s.pop();
            }
        }
        //如果栈没为空就按照栈中原样直接出栈
        while(!s.empty()){
            res[cnt++] = s.pop();
        }
        return res;
    }
}
相关推荐
么么...9 分钟前
布隆过滤器详解:原理、实现与应用
java·数据结构·哈希算法·散列表
Sheep Shaun24 分钟前
深入理解红黑树:从概念到完整C++实现详解
java·开发语言·数据结构·c++·b树·算法
tobias.b40 分钟前
408真题解析-2010-3-数据结构-线索二叉树
数据结构·链表·计算机考研·408真题解析
tobias.b40 分钟前
408真题解析-2010-2-数据结构-双端队列
数据结构·计算机考研·408真题解析
旭意41 分钟前
数据结构-红黑树和set
数据结构·c++·算法·蓝桥杯
宵时待雨41 分钟前
数据结构(初阶)笔记归纳7:链表OJ
c语言·开发语言·数据结构·笔记·算法·链表
充值修改昵称42 分钟前
数据结构基础:堆高效数据结构全面解析
数据结构·python·算法
好奇龙猫43 分钟前
【大学院-筆記試験練習:线性代数和数据结构(15)】
数据结构·线性代数
mjhcsp1 小时前
P14977 [USACO26JAN1] Lineup Queries S(题解)
数据结构·c++·算法
西瓜泡泡奶1 小时前
代码随想录算法Day13|(二叉树part3)110.平衡二叉树、257. 二叉树的所有路径、404.左叶子之和、222.完全二叉树的节点个数
数据结构·算法·二叉树·平衡二叉树·完全二叉树·二叉树路径·左叶子之和