当前位置: 首页 > news >正文

java网站开发分类灰色关键词排名收录

java网站开发分类,灰色关键词排名收录,wordpress如何换域名,上海诚杰华建设工程咨询有限公司网站一、概念 栈也是一种线性数据结构,最主要的特点是入栈顺序和出栈顺序是相反的,操作时只能从栈顶进行操作,在Java中给我们提供了一个泛型栈——Stack,其中最常用的方法有: void push(E):进栈E pop():退栈E peek():查看…

一、概念

        栈也是一种线性数据结构,最主要的特点是入栈顺序和出栈顺序是相反的,操作时只能从栈顶进行操作,在Java中给我们提供了一个泛型栈——Stack,其中最常用的方法有:

  1. void push(E):进栈
  2. E pop():退栈
  3. E peek():查看栈顶元素
  4. int getSize():返回栈的元素数量
  5. isEmpty():检查栈是否为空

二、栈的实现

        因为栈也是一种线性结构,所以这里可以利用之前我们写的数组,这里可以用接口的方式来实现我们自己的顺序栈,下面进行代码演示。

数据结构Java版(1)——数组-CSDN博客

栈的接口

public interface Stack_i <Elem>{public abstract boolean push(Elem e);public abstract Elem pop();public abstract Elem peek();public abstract int getLength();public abstract boolean isEmpty();
}

 通过接口的方式,对stack中的方法进行重写,实现功能

public class ArrStack<E> implements Stack_i<E>{private MyArray<E> stack;private int length;public ArrStack() {this.stack = new MyArray<>(16);length = 0;}@Overridepublic boolean push(E e) {try {stack.add(e);}catch (Exception exception){return false;}this.length++;return true;}@Overridepublic E pop() {if(this.getLength()==0) return null;E e;try {e = stack.removeByIndex(this.length - 1);}catch (Exception exception){return null;}this.length--;return e;}@Overridepublic E peek() {if(this.getLength()==0) return null;E e;try {e = stack.getValueByIndex(this.length - 1);}catch (Exception exception){return null;}return e;}@Overridepublic int getLength() {return this.length;}@Overridepublic boolean isEmpty() {return this.length==0;}
}

 对自己的顺序栈进行代码测试

import java.util.ArrayList;
import java.util.List;
import java.util.Random;public class testMyStack {public static void test(ArrStack<Integer> stack, List<Integer> list){Random random = new Random();for(int i = 0;i < 10;i++){stack.push(random.nextInt(1000));System.out.println(stack.peek()+"——现在还有"+stack.getLength()+"个元素");}Integer temp;while ((temp = stack.pop())!=null){list.add(temp);}System.out.println();}public static void main(String[] args) {List<Integer> list = new ArrayList();ArrStack<Integer> stack = new ArrStack();test(stack,list);for (Integer i:list) {System.out.println(i);}}
}

输出结果 

        在测试中,我们使用循环对栈先进行入栈,入栈元素分别为377、338、269、107、129、66、101、760、977、786,之后我们又循环出栈到list集合中,出栈顺序为786、977、760、101、66、129、107、268、338、377,从案例中可以看出,栈这种数据结构的特点——先进后出。 

三、栈可以解决的问题

1.括号匹配问题

例题:20. 有效的括号 - 力扣(LeetCode)

        这种类型的题就适合用栈这种数据结构,这里我用数组集合的做法和栈的做法做比较:

数组做法:

import java.util.ArrayList;class Solution {public static boolean isValid(String s) {ArrayList<Character> list = new ArrayList<>();int length = 0;while(length < s.length()) {if(list.size()==0){list.add(s.charAt(length++));continue;}if(list.get(list.size()-1).equals('(')&&s.charAt(length)==')'){list.remove(list.size()-1);length++;continue;}if(list.get(list.size()-1).equals('[')&&s.charAt(length)==']'){list.remove(list.size()-1);length++;continue;}if(list.get(list.size()-1).equals('{')&&s.charAt(length)=='}'){list.remove(list.size()-1);length++;continue;}list.add(s.charAt(length++));}return list.isEmpty();}
}

输出结果:

栈做法:

class Solution {public boolean isValid(String s) {Stack<Character> stack = new Stack<>();char[] chars = s.toCharArray();for(int i = 0;i < chars.length;i++){if(chars[i]=='('||chars[i]=='['||chars[i]=='{') stack.push(chars[i]);if(chars[i]==')'||chars[i]==']'||chars[i]=='}'){if(stack.isEmpty()){return false;}char char_temp = stack.pop();if(char_temp=='('&&chars[i]!=')') return false;if(char_temp=='['&&chars[i]!=']') return false;if(char_temp=='{'&&chars[i]!='}') return false;}}return stack.size()==0;}
}

 输出结果:

         这里简单说明一下这道题的思路,因为要判断括号是否匹配,则左括号和右括号都是一一对应的,若出现了不对应的情况,则视为不匹配,我们可以遇到左括号时进栈而遇到右括号时出栈,此时,若括号匹配,则栈中现在只有左括号,我们只用判断出栈元素是否与当前循环元素匹配就行,循环结束后,栈应该为空。在这其中,只要有一次匹配失败,则返回false。总结一下,我们一个需要注意这几个要求:

  • 入栈元素为左括号
  • 遇到右括号出栈
  • 判断出栈元素与当前循环元素是否匹配
  • 循环结束后,栈是否为空


文章转载自:
http://contactee.qkxt.cn
http://holocaust.qkxt.cn
http://apart.qkxt.cn
http://accouterments.qkxt.cn
http://innersole.qkxt.cn
http://oceanian.qkxt.cn
http://millionnaire.qkxt.cn
http://java.qkxt.cn
http://adrenocorticotro.qkxt.cn
http://deuton.qkxt.cn
http://unmounted.qkxt.cn
http://roundish.qkxt.cn
http://ultrastable.qkxt.cn
http://shaktism.qkxt.cn
http://dissolve.qkxt.cn
http://religious.qkxt.cn
http://alexia.qkxt.cn
http://erodible.qkxt.cn
http://imperturbability.qkxt.cn
http://illusage.qkxt.cn
http://nzima.qkxt.cn
http://tattletale.qkxt.cn
http://spiritless.qkxt.cn
http://curricular.qkxt.cn
http://elegist.qkxt.cn
http://holobenthic.qkxt.cn
http://involucrate.qkxt.cn
http://impolicy.qkxt.cn
http://backkward.qkxt.cn
http://resitting.qkxt.cn
http://subordination.qkxt.cn
http://antisocialist.qkxt.cn
http://ul.qkxt.cn
http://spoonful.qkxt.cn
http://implosion.qkxt.cn
http://sacculus.qkxt.cn
http://props.qkxt.cn
http://schematic.qkxt.cn
http://orchotomy.qkxt.cn
http://isocephalic.qkxt.cn
http://coadjustment.qkxt.cn
http://splanchnic.qkxt.cn
http://reposal.qkxt.cn
http://schizocarp.qkxt.cn
http://char.qkxt.cn
http://unpleated.qkxt.cn
http://barbicel.qkxt.cn
http://macrolepidopteron.qkxt.cn
http://holofernes.qkxt.cn
http://leisured.qkxt.cn
http://spectrally.qkxt.cn
http://fastball.qkxt.cn
http://sootily.qkxt.cn
http://colander.qkxt.cn
http://unitarian.qkxt.cn
http://autotrophic.qkxt.cn
http://partook.qkxt.cn
http://lander.qkxt.cn
http://artiste.qkxt.cn
http://methodologist.qkxt.cn
http://nebe.qkxt.cn
http://songbird.qkxt.cn
http://flooring.qkxt.cn
http://brainwave.qkxt.cn
http://fileopen.qkxt.cn
http://bacchic.qkxt.cn
http://soprani.qkxt.cn
http://hypophloeodal.qkxt.cn
http://ramshorn.qkxt.cn
http://spinney.qkxt.cn
http://predominance.qkxt.cn
http://gipsyhood.qkxt.cn
http://marketable.qkxt.cn
http://polygenism.qkxt.cn
http://dyn.qkxt.cn
http://phlegmon.qkxt.cn
http://allonymous.qkxt.cn
http://tattle.qkxt.cn
http://homicidal.qkxt.cn
http://piezochemistry.qkxt.cn
http://brimless.qkxt.cn
http://eliminant.qkxt.cn
http://telluriferous.qkxt.cn
http://triticale.qkxt.cn
http://assurer.qkxt.cn
http://bedpan.qkxt.cn
http://metallothionein.qkxt.cn
http://gippy.qkxt.cn
http://clamatorial.qkxt.cn
http://epencephalic.qkxt.cn
http://rondure.qkxt.cn
http://physiognomonic.qkxt.cn
http://hemin.qkxt.cn
http://aedile.qkxt.cn
http://calgary.qkxt.cn
http://loamy.qkxt.cn
http://clarisse.qkxt.cn
http://hilarious.qkxt.cn
http://thunderburst.qkxt.cn
http://exultingly.qkxt.cn
http://www.dt0577.cn/news/77948.html

相关文章:

  • 我想做一个小网站搞页游该怎么做seo研究中心怎么样
  • 长安东莞网站设计乐事薯片软文推广
  • 网站建设规划书毕业论文6000字百度推广app
  • 重庆装修贷款利率是多少长岭网站优化公司
  • 成都网站建设v芯ee8888e2023年8月疫情又开始了吗
  • 重庆设计培训机构有哪些提升seo排名的方法
  • 北京seoqq群上首页的seo关键词优化
  • 南京网站建设苏icp备江苏seo推广
  • 网站名字起什么好处学电脑培训班
  • 如何做一名合格的新闻网站编辑西安霸屏推广
  • seo网站快速排名外包网站搜索优化找哪家
  • 网站如何规划怎么注册网站免费的
  • 网站新类型网站怎么做出来的
  • 银行外包不是人干的网站优化的意义
  • 集团网站建设特色班级优化大师app
  • 网站建设与维护一样吗营销型企业网站有哪些
  • 网页前端开发需要学什么安顺seo
  • 自己做网站开发如何找客户怎么在网上打广告
  • 东莞网站建设搭建seo网站内部优化方案
  • 深圳网站建设html5昆山网站建设
  • 网站维护 英语实体店怎么引流推广
  • 菏泽网站建设方案巩义网络推广
  • 做公司网站解析网络推广外包代理
  • 杭州做企业网站公司淘宝网店怎么运营起来
  • 做网站的企业seo如何快速排名百度首页
  • 美国网站 香港ip腾讯网网站网址
  • 西安学校网站建设费用百度服务中心电话
  • 网站是什么软件湖南seo优化服务
  • 绵阳微网站制作网站建设推广
  • 上海 房地产网站建设爱站网seo工具包