栈三:栈的压入、弹出序列

/**
 * 题目:栈的压入、弹出序列
 * 描述:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。
 *   例如序列1,2,3,4,5是某 栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。
 *    (注意:这两个序列的长度 是相等的)
 *  注:
 *  1、pushA popA为空时直接返回false
 *  2、创建一个新的stack,将pushA压入stack,每压一个,做一次判断:是否与popA[j]相等,如果相等,将stack出栈,并j++
 *  3、最后如果stack为空,则返回true,反之返回false
 * 方案:  
 *   思路:先进行压栈,压入后与弹出序列递增进行比较,相同弹出,不相同保留,最后判断栈内是否还要元素。(可以在入栈的时候就进行判断,看是否和弹出序列的第一个相同)
 *   如果是该栈的弹出顺序,则下面的for循环中,先进行入栈操作,每次入栈都与弹出序列的第一个数字不相同,直到压入最后一个栈,与之相同,
 *    然后在while里面一次比较,如果有一个不相同,则保留栈内数字,最后栈内还有元素表示不是该栈的弹出序列,
 * */

public class Three {

    public static boolean one(int[] push ,int pop[]) {
        
        if(push.length==0 || pop.length ==0) {
            return false;
        }
        Stack<Integer> stack = new Stack();
        
        for(int i =0,j=0;i<push.length;i++) {
            stack.push(push[i]);
            while(j<pop.length &&stack.peek() == pop[j] ) {  // 每次入栈判断是否和出栈第一个相同,如果相同了,直接出栈,比较出栈序列的第二个和入栈数字,会导致stack一直存放入栈的数据,stack不为空,表示不是该栈的
                stack.pop();
                j++;
            }
        }
        return stack.isEmpty()?true:false;
    }
}

 

转载于:https://www.cnblogs.com/ZeGod/p/9969415.html

已经博主授权,源码转载自 https://pan.quark.cn/s/053f1da40351 在计算机科学领域,MIPS(Microprocessor without Interlocked Pipeline Stages)被视作一种精简指令集计算机(RISC)的架构,其应用广泛存在于教学实践式系统设计中。 本篇内容将深阐释MIPS汇编语言中涉及数组处理的核心概念与实用操作技巧。 数组作为一种常见的数据结构,在编程中能够以有序化的形式储存及访问具有相同类型的数据元素集合。 在MIPS汇编语言环境下,数组通常借助内存地址与索引进行操作。 以下列举了运用MIPS汇编处理数组的关键要素:1. **数据存储**: - MIPS汇编架构采用32位地址系统,从而能够访问高达4GB的内存容量。 - 数组元素一般以连续方式存放在内存之中,且每个元素占据固定大小的字节空间。 例如,针对32位的整型数组,其每个元素将占用4字节的存储空间。 - 数组首元素的地址被称为基地址,而数组任一元素的地址可通过基地址加上元素索引乘以元素尺寸的方式计算得出。 2. **寄存器运用**: - MIPS汇编系统配备了32个通用寄存器,包括$zero, $t0, $s0等。 其中,$zero寄存器通常用于表示恒定的零值,$t0-$t9寄存器用于暂存临时数据,而$s0-$s7寄存器则用于保存子程序的静态变量或参数。 - 在数组处理过程中,基地址常被保存在$s0或$s1寄存器内,索引则存储在$t0或$t1寄存器中,运算结果通常保存在$v0或$v1寄存器。 3. **数组操作指令**: - **Load/Store指令**:这些指令用于在内存与寄存器之间进行数据传输,例如`lw`指令用于加载32位数据至寄存器,`sw`指令...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值