1.3 背包(Bag)、队列(Queue)和栈(Stack)

不同在于删除或者访问对象的顺序不同

1.1 泛型

集合类的抽象数据类型的一个关键特性是我们应该可以用它们存储任意类型的数据。

Java一种机制可以实现,它叫做泛型,也叫做参数化类型。


1.2 自动装箱

1.4 背包

一种不支持从中删除元素的集合数据类型

它的目的就是帮助用例收集元素并迭代遍历所有收集到的元素。

使用Bag可以说明元素的处理顺序不重要。

1.6 下压栈,简称栈

使用foreach语句迭代遍历栈中元素的时候,元素的处理顺序和它们被压入的顺序正好相反。

2.集合类数据类型的实现

2.4 对象游离

保存一个不需要的对象的引用称为游离。(栈的pop)

解决:将被弹出的数组元素的值设为null即可,这将覆盖无用的引用并使系统可以在用例使用完被弹出的元素后回收它的内存。

2.5 迭代


3.链表

定义:链表是一种递归的数据结构,它或者为空(null),或者是指向一个结点(node)的引用,该结点含有一个泛型的元素和一个指向另一条链表的引用

链表比数组插入元素或是删除元素都更方便

实现任意插入和删除操作的标准解决方案是双向链表

3.8 栈的实现

栈是由链表实现

链表的使用达到了最优的设计目标:

它可以处理任意类型的数据

所需的空间总是和集合的大小成正比

操作所需的时间总是和集合的大小无关



3.9 队列的实现

3.10 背包的实现

总结

数据类型的值就是一组对象的集合:背包、队列、栈(三种基础数据类型)

两种表示对象集合的方式:数组和链表

答疑

为什么Java不允许泛型数组?

数组的协变性(covariant)是指:

如果类Base是类Sub的基类,那么Base[]就是Sub[]的基类。

而泛型是不可变的(invariant),List不会是List的基类,更不会是它的子类。

数组是具体化的(reified),而泛型在运行时是被擦除的(erasure)。

数组是在运行时才去判断数组元素的类型约束,

而泛型正好相反,在运行时,泛型的类型信息是会被擦除的,只有编译的时候才会对类型进行强化。

前序表达式():即从右至左取数,直到取出一个运算符,将刚取出的紧挨着运算符的两个操作数按运算符进行计算,结果回填至运算符。重复该步骤,直到最后只剩下一个字符串则剩下的字符串即为结果。

中序表达式:我们平时用的

后序表达式:字符串扫描方式正好和前序相反,是从左往右扫描,规则类似。

前序表达式

+/*23-21*3-41

中序表达式

2*3/(2-1)+3*(4-1)

后序表达式

23*21-/341-*+

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在经过一次没有准备的面试后,发现自己虽然写了两年的android代码,基础知识却忘的差不多了。这是程序员的大忌,没...
    猿来如痴阅读 2,898评论 3 10
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,395评论 11 349
  • 第一章:Java程序设计概述 Java和C++最大的不同在于Java采用的指针模型可以消除重写内存和损坏数据的可能...
    loneyzhou阅读 1,298评论 1 7
  • B 周小鲸抄完数学作业的最后一题,长长的舒了一口气。 这时,她抬起头来。 咔。是谁关上了开关。 天地间一下子安静了...
    鹿琦花阅读 249评论 0 0
  • 少平与晓霞,少安与润叶,少安与秀连,向前对润叶,秀对少平,惠明与莉莉……平凡的世界或不平凡的世界里都充斥着感情,或...
    某呆子阅读 253评论 0 0