java实现 数据结构:链表、 栈、 队列、优先级队列、哈希表
最近在准备找工作的事情,就复习了一下java。翻了一下书和网上的教材,发现虽然很多书是用java讲数据结构的,但是侧重于将数据结构本身的知识,利用java本身的类库来实现数据结构的系统性的讲解少之又少,所以在此做一下总结,方便各位正在准备工作的和用java实现数据结构的朋友们。
附:代码下载:http://download.csdn.net/detail/sunnyskyliu/4754827
栈:
- void m_stack()
- {
- //Stack
- Stack<String> st=new Stack<String>();
- //Stack<Integer> st=new Stack<Integer>();
- st.push("1a");
- st.push("2b");
- st.push("3c");
- st.push("4d");
- System.out.println("pop is:"+st.pop());
- System.out.println("size is:"+st.size());
- System.out.println("peek is:"+st.peek());
- System.out.println("isEmpty is:"+st.isEmpty());
- System.out.println("toString is:"+st.toString());
- System.out.println();
- }
队列:
- void m_queue()
- {
- //Queue
- Queue<String> qu=new LinkedList<String>();//wrong:Queue<String> qu=new Queue<String>();
- qu.add("1a");
- qu.add("2b");
- qu.add("3c");
- qu.add("4d");
- //qu.offer("4d");//equal to add,but no exception
- System.out.println("remove is:"+qu.remove());
- //System.out.println("poll is:"+qu.poll());//equal to remove,but no exception
- System.out.println("peek is:"+qu.peek());
- System.out.println(qu.toString());
- System.out.println();
- }
优先级队列:
- class m_priorityQueue extends PriorityQueue<m_priorityQueue>
- implements Comparable<m_priorityQueue>
- {
- private char primary;
- private int secondary;
- private String item;
- public m_priorityQueue(String td,char pri,int sec){
- item = td;
- primary = pri;
- secondary = sec;
- }
- //for comparable
- public int compareTo(m_priorityQueue arg) {
- if(primary > arg.primary)
- return +1;
- if(primary == arg.primary)
- if(secondary > arg.secondary)
- return +1;
- else if(secondary == arg.secondary)
- return 0;
- return -1;
- }
- public String toString()
- {
- return Character.toString(primary)+ secondary + ": " + item;
- }
- public void add(String td,char pri,int sec)
- {
- super.add(new m_priorityQueue(td,pri,sec));
- }
- public void run()
- {
- add("sixth",'C',4);
- add("second",'A',2);
- add("fourth",'B',7);
- add("fifth",'C',3);
- add("first",'A',1);
- add("third",'B',1);
- while(!isEmpty())
- System.out.println(remove());
- }
- }
链表:
- //link list
- void m_linkList()
- {
- LinkedList<String> head = new LinkedList<String>();
- head.add("1");
- head.add("3");
- head.add(1, "2");
- //鏈表會自動用遍歷的方式打印所有內容
- System.out.println(head);
- System.out.println("size is:"+head.size());
- //利用Vector或者是ArrayList等Collection往鏈表中加數據
- Vector<String> v = new Vector<String>(); //need to import java.util.Vector;
- //LinkedList<String> v=new LinkedList<String>();
- //向Vector中加入東西
- v.add("a");
- v.add("b");
- //將當前Vector加在當前鏈表的最后
- head.addAll(v);
- System.out.println(head);
- //將當前Vector加在當前鏈表的指定位置
- head.addAll(2, v);
- System.out.println(head);
- //打印指定位置的內容
- System.out.println("get(2) is:"+head.get(2));
- System.out.println("index is:"+head.indexOf(head.get(2)));
- head.addFirst("fist");
- head.addLast("last");
- System.out.println(head);
- //刪除第一個
- head.remove(head.getFirst());
- head.remove(head.getLast());
- System.out.println(head);
- //再刪除第一個,采用下標的方式,下標從0開始
- head.remove(0);
- System.out.println(head);
- System.out.println();
- }
( 鸣谢:http://wangyu.iteye.com/blog/190762)
哈希:
- void m_hash()
- {
- Hashtable<String, Integer> h=new Hashtable<String, Integer>();
- h.put("用户1",new Integer(90));
- h.put("用户2",new Integer(50));
- h.put("用户3",new Integer(60));
- h.put("用户4",new Integer(70));
- h.put("用户1",new Integer(80));
- System.out.println("用户1: "+h.get("用户1"));
- /*
- //枚举
- Enumeration<Integer> e=h.elements();
- while(e.hasMoreElements())
- {
- System.out.println(e.nextElement());
- }*/
- for(Iterator<String> itor=h.keySet().iterator(); itor.hasNext();)
- {
- String word=itor.next().toString();
- Integer in=(Integer)h.get(word);
- System.out.println("word: "+word+" time:"+in);
- }
- }
main调用:
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- dataStructure da=new dataStructure();
- da.m_stack();
- da.m_queue();
- da.m_linkList();
- da.m_hash();
- dataStructure.m_priorityQueue pqueue=da.new m_priorityQueue(null, '0', 0);
- pqueue.run();
- }
java实现 数据结构:链表、 栈、 队列、优先级队列、哈希表的更多相关文章
- java面向对象的栈 队列 优先级队列的比较
栈 队列 有序队列数据结构的生命周期比那些数据库类型的结构(比如链表,树)要短得多.在程序操作执行期间他们才被创建,通常用他们去执行某项特殊的任务:当完成任务之后,他们就会被销毁.这三个数据结构还有一 ...
- 自己动手实现java数据结构(八) 优先级队列
1.优先级队列介绍 1.1 优先级队列 有时在调度任务时,我们会想要先处理优先级更高的任务.例如,对于同一个柜台,在决定队列中下一个服务的用户时,总是倾向于优先服务VIP用户,而让普通用户等待,即使普 ...
- java数据结构与算法值优先级队列
一.优先级队列 什么是优先级队列:优先级队列是一种比栈和队列更加常用的一种数据结构.在优先级队列中,数据项按照关键字的值有序.数据项插入到队列中时,会按照顺序插入到合适的位置,用来保证队列的顺序. 生 ...
- C#部分---特殊集合:stack栈集合、queue队列集合、哈希表集合。
1.stack栈集合:又名 干草堆集合 栈集合 特点:(1)一个一个赋值 一个一个取值(2)先进后出实例化 初始化 Stack st = new Stack(); //添加元素用push st.Pus ...
- Stack集合 Queue队列集合 Hashtable哈希表
Stack集合 干草堆集合 栈集合 栈;stack,先进后出,一个一个赋值,一个一个取值,安装顺序来. 属性和方法 实例化 初始化 Stack st = new Stack(); 添加元素 个数 Co ...
- Java数据结构和算法(十三)——哈希表
Hash表也称散列表,也有直接译作哈希表,Hash表是一种根据关键字值(key - value)而直接进行访问的数据结构.它基于数组,通过把关键字映射到数组的某个下标来加快查找速度,但是又和数组.链表 ...
- 数据结构与算法Python版 熟悉哈希表,了解Python字典底层实现
Hash Table 散列表(hash table)也被称为哈希表,它是一种根据键(key)来存储值(value)的特殊线性结构. 常用于迅速的无序单点查找,其查找速度可达到常数级别的O(1). 散列 ...
- [数据结构 - 第8章] 查找之哈希表(C语言实现)
首先是需要定义一个哈希表的结构以及一些相关的常数.其中 HashTable 就是哈希表结构.结构当中的 elem 为一个动态数组. #define HASHSIZE 12 // 定义哈希表长为数组的长 ...
- Java堆(heap)、栈(stack)和队列的区别
Java里面Stack有两种含义: 一:数据结构 Stack,即java.util.Stack import java.util.Stack; import java.util.Iterator; i ...
- JavaScript数据结构与算法(三) 优先级队列的实现
TypeScript方式实现源码 // Queue类和PriorityQueue类实现上的区别是,要向PriorityQueue添加元素,需要创建一个特殊的元素.这个元素包含了要添加到队列的元素(它可 ...
随机推荐
- poj 3321(带时间戳 + 区间统计)
题目描述: 给定一颗树,求某个节点的子树的val值之和 可以用树的前序遍历给每一个节点编号,从而可以确定一个节点的子树的范围,这样就可以进行直接在区间上进行统计了. vector < int & ...
- vue 生命周期钩子 过滤器 计算属性
每一个Vue实例在被创建之前都要经过一系列的初始化过程.例如,实例需要配置数据观测.编译模板.挂载实例到DOM,然后在数据变化时更新DOM,在这个过程中,实例也会调用一些生命周期钩子,这就给我们提供了 ...
- vertical-align 和line-height 以及baseline的解析
line-height是相对于font-size来计算的,vertical-align的百分比值是相对于line-height来计算的,vertical-align的默认是baseline; demo ...
- 用jQuery插件来提升SharePoint列表表单用户体验
本文将描述如何通过简单的CSS和jQuery插件提升SharePoint默认的列表表单体验.这些小技巧并不仅仅改善了外观,还提升了可用性. 剩余字数 我们以通知列表为例.通知正文字段假设要求不应该超过 ...
- 虚拟机安装hadoop
1.用VMware建立两台虚拟机(Centos6.5)系统,并设立主机名为node1与node2 2.设置虚拟机网络两台都是设置为如图: 3.修改两台虚拟机的/etc/hosts的文件为 (其中192 ...
- ThinkPHP3.2.3学习笔记4---统计ThinkPHP3.2.3加载的文件
将ThinkPHP3.2.3的入口文件index.php加入一个函数getIncludeFiles,文件内容变成如下所示: <?php // +------------------------- ...
- [SDOI2016]墙上的句子
题目描述 考古学家发现了一堵写有未知语言的白色墙壁,上面有一个n行m列的格子,其中有些格子内被填入了某个A至Z的大写字母,还有些格子是空白的. 一直横着或竖着的连续若干个字母会形成一个单词,且每一行的 ...
- synchronized(1)用法简介:修饰方法,修饰语句块
注意: 同一个对象或方法在不同线程中才出现同步问题,不同对象在不同线程互相不干扰. synchronized方法有2种用法:修饰方法,修饰语句块 1.synchronized方法 是某个对象实例内,s ...
- java awt 乱码问题
问题:项目环境是utf-8,awt的元件比如label一直乱码 解决: (eclipse) 1.在你的具有main函数的类也即你应用运行的主类上点击右键,选择Run As中的Run Configura ...
- Hadoop集群搭建及MapReduce应用
一.Hadoop集群的搭建与配置 1.节点准备 集群规划: 主机名 IP 安装的软件 运行的进程 weekend 01 192.168.1.60 jdk.hadoop NameNode.DFSZKFa ...