首先想要实现栈,就得知道栈为何物,以下一段摘抄至百度百科:

  栈(stack)又名堆栈,它是一种运算受限的线性表。其限制是仅允许在表的一端进行插入和删除运算。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

        栈的模型图


大致了解了栈这种数据结构后,我们就尝试着将其实现吧。

首先,我们需要定义一个Stack接口,代码如下:

public interface Stack<E> {
int getSize();//得到栈的大小
boolean isEmpty();//判断栈是否为空
void push(E e);//压栈
E pop();//出栈
E peek();//查看栈顶元素
}

由于在<数据结构系列1>(https://www.cnblogs.com/LASloner/p/10721407.html)中我们已经实现了ArrayList,所以今天我们就用Array来作为Stack的数据存储方式吧:

public class ArrayStack<E> implements Stack<E>{

    //这里用的是自己实现的Array,当然读者可以直接用Java自带的ArrayList,效果相同
private Array<E> array; //有参构造
public ArrayStack(int capacity){
array=new Array<E>(capacity);
}
//无参构造
public ArrayStack() {
array=new Array<E>();
} //获取栈的大小
@Override
public int getSize() {
return array.getSize();
} //判断栈是否为空
@Override
public boolean isEmpty() {
return array.isEmpty();
} //压栈(向栈顶添加元素)
@Override
public void push(E e) {
array.addLast(e);
} //出栈(取出栈顶元素)
@Override
public E pop() {
return array.removeLast();
} //查看栈顶元素
@Override
public E peek() {
return array.get(array.getSize()-1);
} @Override
public String toString() {
StringBuilder res=new StringBuilder();
res.append("Stack: ");
res.append('[');
for (int i=0;i<array.getSize();i++) {
res.append(array.get(i));
if(array.getSize()-1!=i)
res.append(", ");
}
res.append("] top");
return res.toString();
}
}

当当,这就实现了栈的结构,其实也没那么复杂嘛(当然实现栈的数据存储方式还有很多,不仅仅是数组,还有链表,在我们学习过链表后,就尝试用链表也实现一下)

okey,让我们测试一下

Main代码:

public class Main {
public static void main(String[] args) { ArrayStack<Integer> stack = new ArrayStack<>(); for(int i = 0 ; i < 5 ; i ++){
stack.push(i);
System.out.println("入栈:"+stack);
}
System.out.println("--------------------------"); stack.pop();
System.out.println("出栈:"+stack);
System.out.println("--------------------------"); System.out.println("查看栈顶元素:"+stack.peek());
System.out.println(stack);
}
}

输出如下:

入栈:Stack: [0] top
入栈:Stack: [0, 1] top
入栈:Stack: [0, 1, 2] top
入栈:Stack: [0, 1, 2, 3] top
入栈:Stack: [0, 1, 2, 3, 4] top
--------------------------
出栈:Stack: [0, 1, 2, 3] top
--------------------------
查看栈顶元素:3
Stack: [0, 1, 2, 3] top

那老规矩,再看一下栈中各种操作的时间复杂度吧:

ArrayStack<E>:
void push(E) O(1)
E pop() O(1)
E peek() O(1)
int getSize() O(1)
boolean isEmpty O(1)

最后用一个实例来应用一下 栈 这种数据结构吧:

  /*有效的括号
给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
*/
public class Solution {
public boolean isValid(String s) {
ArrayStack<Character> stack=new ArrayStack<>();
for(int i=0;i<s.length();i++) {
char c=s.charAt(i);
if(c == '(' || c == '[' || c == '{')
stack.push(c);
else{
if(stack.isEmpty())return false;
char topChar=stack.pop();
if(c == ')' && topChar != '(')
return false;
if(c == ']' && topChar != '[')
return false;
if(c == '}' && topChar != '{')
return false;
}
}
return true;
} public static void main(String[] args) {
System.out.println(new Solution().isValid("()[]{}"));
System.out.println(new Solution().isValid("([)]"));
}
} 输出:
true
flase

ok,今天的学习就这样了。有什么问题,希望各位能够多多指正。

对于学习,四个字概括:至死方休

<数据结构系列2>栈的实现与应用(LeetCode<有效的的括号>)的更多相关文章

  1. 【C#数据结构系列】栈和队列

    一:栈 栈和队列也是线性结构,线性表.栈和队列这三种数据结构的数据元素以及数据元素间的逻辑关系完全相同,差别是线性表的操作不受限制,而栈和队列的操作受到限制.栈的操作只能在表的一端进行,队列的插入操作 ...

  2. Java数据结构系列之——栈(2):栈的链式存储结构及其操作

    package Stack; import LinkList.SinglyLinkList; public class LinkListStack { private SinglyLinkList&l ...

  3. JAVA数据结构系列 栈

    java数据结构系列之栈 手写栈 1.利用链表做出栈,因为栈的特殊,插入删除操作都是在栈顶进行,链表不用担心栈的长度,所以链表再合适不过了,非常好用,不过它在插入和删除元素的时候,速度比数组栈慢,因为 ...

  4. <数据结构系列3>队列的实现与变形(循环队列)

    数据结构第三课了,今天我们再介绍一种很常见的线性表——队列 就像它的名字,队列这种数据结构就如同生活中的排队一样,队首出队,队尾进队.以下一段是百度百科中对队列的解释: 队列是一种特殊的线性表,特殊之 ...

  5. 【JavaScript数据结构系列】03-队列Queue

    [JavaScript数据结构系列]03-队列Queue 码路工人 CoderMonkey 转载请注明作者与出处 1. 认识队列Queue结构 队列,跟我们的日常生活非常贴近,我们前面举例了食堂排队打 ...

  6. 【JavaScript数据结构系列】04-优先队列PriorityQueue

    [JavaScript数据结构系列]04-优先队列PriorityQueue 码路工人 CoderMonkey 转载请注明作者与出处 ## 1. 认识优先级队列 经典的案例场景: 登机时经济舱的普通队 ...

  7. 【JavaScript数据结构系列】02-栈Stack

    [JavaScript数据结构系列]02-栈Stack 码路工人 CoderMonkey 转载请注明作者与出处 ## 1. 认识栈结构 栈是非常常用的一种数据结构,与数组同属线性数据结构,不同于数组的 ...

  8. 【JavaScript数据结构系列】01-数组Array

    [JavaScript数据结构系列]01-数组Array 码路工人 CoderMonkey 转载请注明作者与出处 # [JavaScript数据结构系列] # 01-数组Array 数组: 是有序的元 ...

  9. 【JavaScript数据结构系列】00-开篇

    [JavaScript数据结构系列]00-开篇 码路工人 CoderMonkey 转载请注明作者与出处 ## 0. 开篇[JavaScript数据结构与算法] 大的计划,写以下两部分: 1[JavaS ...

随机推荐

  1. oracle order by 自定义

    我们通常需要根据客户需求对于查询出来的结果给客户提供自定义的排序方式,那么我们通常sql需要实现方式都有哪些,参考更多资料总结如下(不完善的和错误望大家指出): 一.如果我们只是对于在某个程序中的应用 ...

  2. U-Boot Driver Model领域模型设计 (转)

    需求分析 在2014年以前,uboot没有一种类似于linux kernel的设备驱动模型,随着uboot支持的设备越来越多,其一直受到如下问题困扰: 设备初始化流程都独立实现,而且为了集成到系统,需 ...

  3. 使用SpringAOP实现事务(声明式事务管理、零配置)

    前言: 声明式事务管理建立在AOP之上的.其本质是对方法前后进行拦截,然后在目标方法开始之前创建或者加入一个事务,在执行完目标方法之后根据执行情况提交或者回滚事务.声明式事务最大的优点就是不需要通过编 ...

  4. vue使用echart中国地图

    /* 引入 ECharts (按需加载) 文档:http://echarts.baidu.com/tutorial.html#%E5%9C%A8%20webpack%20%E4%B8%AD%E4%BD ...

  5. Hangfire:任务定时调度

    hangfire 资源: GitHub:https://github.com/HangfireIO/Hangfire http://hangfire.io/ http://docs.hangfire. ...

  6. Python CGI编程Ⅷ

    通过CGI程序传递checkbox数据 checkbox用于提交一个或者多个选项数据,HTML代码如下: 以下为 checkbox.py 文件的代码: 修改 checkbox.py 权限: 通过CGI ...

  7. 1、Qt应用程序

    新建Qt Widgets Application,基类选择QWidget Qt项目特点(参考上图):头文件名与类名一样,成对出现 main.cpp代码解释如下 #include "mywid ...

  8. TTTTTTTTTTTTTTTTTT POJ 2724 奶酪消毒机 二分匹配 建图 比较难想

    Purifying Machine Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 5004   Accepted: 1444 ...

  9. A. Transmigration

    A. Transmigration time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  10. log4j动态配置参数

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...