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

杭州企业网站设计模板高端装修公司怎么获客

杭州企业网站设计模板,高端装修公司怎么获客,网站开发终止合作协议,泉州专业网站建设公司一、前言 之前我们已经学习了链表的所有操作及其时间复杂度分析,我们可以了解到对于链表头的相关操作基本都是O(1)的,例如链表头增加、删除元素,查询元素等等。那我们其实有一个数据结构其实可以完美利用到这些操作的特点,都是在…

一、前言

之前我们已经学习了链表的所有操作及其时间复杂度分析,我们可以了解到对于链表头的相关操作基本都是O(1)的,例如链表头增加、删除元素,查询元素等等那我们其实有一个数据结构其实可以完美利用到这些操作的特点,都是在某一段进行操作,那就是栈。本章我们通过链表去实现栈。并且比较用数组实现和用链表实现他们之间的差异。

二、用链表实现栈

2.1、代码实现

那么通过链表实现栈就很简单了,我们知道入栈和出栈都是从链表的同一端进行操作,那么我们只需调用链表的addFirst/removeFirst的方法即可,查找同理。
首先我们将链表栈命名为LinkedListStack,并且实现我们Stack的抽象类,然后设置一个内部属性为我们之前实现的链表,通过该链表完成实现需要重写的方法即可,代码如下:

public class LinkedListStack<T> implements Stack<T> {private LinkedList<T> linkedList;public LinkedListStack() {this.linkedList = new LinkedList<>();}@Overridepublic int getSize() {return linkedList.getSize();}@Overridepublic boolean isEmpty() {return linkedList.isEmpty();}@Overridepublic void push(T t) {linkedList.addFirst(t);}@Overridepublic T pop() {return linkedList.removeFirst();}@Overridepublic T peek() {return linkedList.getFirst();}@Overridepublic String toString() {StringBuilder stringBuilder = new StringBuilder();stringBuilder.append("Stack: top ");stringBuilder.append(linkedList);return stringBuilder.toString();}
}

测试一下:

public static void main(String[] args) {LinkedListStack<Integer> integerArrayStack = new LinkedListStack<>();for (int i = 0; i < 5; i++) {integerArrayStack.push(i);System.out.println(integerArrayStack);}integerArrayStack.pop();System.out.println(integerArrayStack);}

结果没有问题,通过链表实现栈就这样简单的实现了。
在这里插入图片描述

2.2、和数组栈比较性能

这个代码和之前数组队列和循环队列效率的对比很接近:

public class TestStackCompare {private static double testQueue(Stack<Integer> s, int opCount){long startTime = System.currentTimeMillis();Random random = new Random();for (int i = 0; i < opCount; i++) {s.push(random.nextInt(Integer.MAX_VALUE));}for (int i = 0; i < opCount; i++) {s.pop();}long endTime = System.currentTimeMillis();return (endTime - startTime)/1000.0;}public static void main(String[] args) {ArrayStack<Integer> integerArrayStack = new ArrayStack<>();LinkedListStack<Integer> integerLinkedListStack = new LinkedListStack<>();System.out.println("arrayStack,time:"+testQueue(integerArrayStack,1000000)+"s");System.out.println("linkedListStack,time:"+testQueue(integerLinkedListStack,1000000)+"s");}
}

那么我们运行下,发现两者效率近乎一致:
在这里插入图片描述
当然也有可能得到的结果是有差距的,对于arrayStack来说,时不时就需要扩容,这个对于某些操作系统来说比较耗费时间,而对于linkedListStack来说,它每次new Node就需要不断的开辟空间,这个操作又对于某些操作系统来说更耗费时间;而且这两者的差距会随着操作次数的增多不断拉大,因为扩容并不是每次扩容,而new Node确实是需要每次都new一个,例如我将操作次数放大为10000000次,这个时候两者的时间差距就比较大了:
在这里插入图片描述

所以仍然取决于你测试使用的操作系统,配置,jvm版本等等。但是其实我想强调的是,对于数组栈和链表栈来说,他们的各项操作的时间复杂度其实是一致的。他们之间没有复杂度之间的巨大差异。不像数组队列和循环队列,一个6s,一个0.01s,这之间的差距是非常大的。

http://www.yayakq.cn/news/830032/

相关文章:

  • 做网站的工作流程做a免费视频在线观看网站
  • 24小时学会网站建设下载旅游网页首页
  • 企业网站模板论坛淄博乐达网站建设
  • 宿州公司做网站北白象镇做公司网站哪里有
  • 盾思途旅游网站建设seo网站结构优化的方法
  • 我想采集散文 做网站站长工具查询网
  • 两个网站如何做端口映射广州网站平台怎么做
  • vue.js 可以做网站吗做网站页面一般用什么软件
  • 甘肃网站建设公司wordpress英文意思
  • 网站建设客户怎么寻找做楼盘网站
  • 网站建设公司antnw通用ppt模板免费
  • 如果建网站在线装修设计平台
  • 中企动力技术支持网站wordpress非插件使用七牛云存储
  • 舆情网站直接打开怎么弄品牌建设再发力
  • 北京国互网网站建设价格能做wordpress的网站
  • 专业的网站开发团队需要哪些人重庆市网站建设
  • thinkphp手机网站制作建筑业企业资质证书多少钱
  • 购物商城网站开发公司wordpress原因跳转
  • 做网站编辑累不累2015军考网站建设
  • 南宁网站建设服务公司镇江seo方案
  • 同ip网站做301百度网址大全官方网站
  • 肇庆广宁住房和城乡建设部网站qq网页版在线登录官网
  • 推广网站报价wordpress调用友情链接
  • 聊城建设网站建设一个小游戏网站
  • 崇信网站建设西安网站托管公司招聘
  • 女人与狗做视频网站佛山公司网站建设价格
  • 网站建设怎么放到云空间常熟建设合同备案在哪个网站
  • 网站开发的概要设计模板深圳建设网站哪家最好
  • 建设网站的公司兴田德润在哪里企业网上的推广
  • 宁波建网站如何收费wordpress 媒体库加载不了图片