栈的基本操作

目录

一、什么是栈?

 二、用单链表实现栈

 三、用顺序表数组实现栈


一、什么是栈?

·栈(stack)是一个先进后出(FILO-First In Last Out)的有序列表。

·主要方法:入栈(push)、出栈(pop)

·允许插入和删除的一端为变化的一端,称为栈顶(Top),另一端为固定的一端,称为栈底(Bottom)。

·先放入到栈的元素在栈底,后放入栈的元素为栈顶。栈顶的元素先出,栈底的元素后出。

·栈的应用场景:(1)递归问题的处理(2)表达式的转换,例如括号、计算器。(3)二叉树的遍历(4)图的深度优先遍历

 二、用单链表实现栈

思路:用链表的方式实现栈
将插入的结点插入到第一个结点位置,如果插入到链表的尾部的话,虽然插入尾部可以后进先出,但每次拿到元素都要遍历到链表的尾部,效率太低了,所以将结点插入到链表头部,每次从链表头部获取结点,达到后进先出的效果。 

 代码实现:

package Stack;

public class MyLinkedStack<T> {

    //定义链表结点
    public class Node{
        T item;//存储数据
        Node next;
        public Node(T item, Node node) {
            this.item = item;
            this.next = node;
        }
    }

    //定义头结点
    Node head;
    //定义栈的长度
    int size;
    //初始化头结点、栈的长度

    public MyLinkedStack() {
        head = new Node(null,null);
        size = 0;
    }

    //定义入栈方法
    //思路:用链表的方式实现栈
    //     将插入的结点插入到第一个结点位置,如果插入到链表的尾部的话,
    //     虽然插入尾部可以后进先出,但每次拿到元素都要遍历到链表的尾部,
    //     效率太低了,所以将结点插入到链表头部,每次从链表头部获取结点,达到后进先出的效果。
    public void push(T t){
        //获取第一个结点
        Node first = this.head.next;
        //创建插入的结点
        Node node = new Node(t,null);
        //将需要插入的结点指针指向第一个结点
        node.next = first;
        //将头结点指针指向插入的结点
        this.head.next = node;
        //链表的长度加一
        this.size++;
    }

    //定义出栈方法
    public T pop(){
        //获取第一个结点
        Node first = this.head.next;
        //获取第二个节点
        Node second = first.next;
        //取出第一个结点,将头结点指向第二个节点
        this.head.next = second;
        //链表的长度减一
        this.size--;
        //return获取结点
        return first.item;
    }
}

 三、用顺序表数组实现栈

 这里讲一下思路即可,代码实现先不贴上去哈。

思路:数组实现的原理很简单,每次插入元素都放在数组的尾部,每次获取元素也从数组尾部获取即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值