一、List接口,有序的Collection接口,能够精确地控制每个元素插入的位置,允许有相同的元素

1.链表,LinkedList实现了List接口,允许null元素,提供了get()、remove()、insert()方法,没有同步方法

  1. public void add() {
  2. LinkedList List = new LinkedList();
  3. List.add("link1");
  4. List.add("link2");
  5. List.add("link3");
  6. Iterator it = List.iterator();
  7. while (it.hasNext()) {
  8. System.out.println(it.next());
  9. }
  10. it.remove();
  11. Iterator it1 = List.iterator();
  12. for (int i = 0; i < List.size(); i++) {
  13. System.out.println(it1.next());
  14. }
  15. }

2.数组列表,ArrayList,可以动态变化容量的数组,非同步的

数组列表中存放的是Object类型,因此在数组列表中存放的对象类型,以其原型的父类代替,提取其中的元素时要进行类型转换

  1. public static void main(String[] args)
  2. {
  3. ArrayList al=new ArrayList();
  4. al.add("name");
  5. al.add("value");
  6. al.add("number");
  7. for(int i=0;i<al.size();i++)
  8. {
  9. System.out.println(al.get(i));
  10. }
  11. }

二、Set接口,不包含重复元素的Collection接口
1.散列集,HashSet,实现了Set接口,非线性同步
与链表和数组列表几乎类似,但在数据处理时,比使用链表进行数据处理花费时间更短,处理大数据时通常使用散列集

  1. public static void main(String[] args)
  2. {
  3. long time=0;
  4. HashSet hs=new HashSet();
  5. ArrayList al=new ArrayList();
  6. long starttime=System.currentTimeMillis();
  7. for(int i=0;i<10000;i++)
  8. {
  9. hs.add(new Integer(i));
  10. }
  11. System.out.println(System.currentTimeMillis()-starttime);
  12. for(int i=0;i<10000;i++)
  13. {
  14. al.add(new Integer(i));
  15. }
  16. System.out.println(System.currentTimeMillis()-starttime);
  17. }

2.树集,TreeSet,实现了Set接口,实现了排序功能,该集合中的元素默认按升序排列元素
使用树集数据结构的对象,需要实现Comparable接口,树集输出的数据都是经过排序的

三、Map接口,没有继承Collection接口,其提供key到value的映射,Map中不能包含相同的key,每个key只能映射一个value。
1.散列表类,HashTable,继承了Map接口,非空(non-null)的对象都可作为key或value,是同步的
添加数据:put(key,value);
取出数据:get(key);
特点:无序的,因此可以快速查找特定的元素

  1. public static void TableTest(){
  2. Hashtable ht = new Hashtable();
  3. ht.put("key1", "value1");
  4. ht.put("key2", "value2");
  5. String value1=(String)ht.get("key2");
  6. System.out.println(value1);
  7. }

构造函数:Hashtable(),初始容量11,负载因子0.75,即散列表中已经有75%的位置被放满,则进行再散列。
负载因子越高(越接近1),则内存使用率越高,元素的寻找时间越长,反之,则内存浪费越多,寻找时间越短
key的对象将通过计算散函数确定与之对应的value位置 ,因此key的对象需要实现hashCode()和equals()方法。
两个对象相同,则它们的hashCode必须相同;两个对象不同,则它们的hashCode不一定不同。
冲突:不同对象的hashCode相同,则称为冲突,冲突将导致操作散列表的时间开销增大。因此要同时复写equals()和hashCode()方法
2.散列映射类,HashMap,与HashTable类似,不是HashMap是非同步的,且允许null

  1. public static void Maptest(){
  2. Map<string string=""> map=new HashMap<string string="">();
  3. map.put("key1", "value1");
  4. map.put("key2", "value2");
  5. map.put("key3", "value3");
  6. for(Map.Entry<string string=""> entry:map.entrySet()){
  7. System.out.println(entry.getKey());
  8. System.out.println(entry.getValue());
  9. }
  10. String value1=(String)map.get("key1");
  11. System.out.println(value1);
  12. }
  13. </string></string></string>

3.树映像,TreeMap,输出的数据按照关键字排序了

【转】http://blog.csdn.net/hunterno4/article/details/9750577

java数据结构整理(二)的更多相关文章

  1. Java数据结构整理(一)

    ava数据结构内容整理关键字: 数据结构 Collection:List.SetMap:HashMap.HashTable如何在它们之间选择一.Array , ArraysJava所有“存储及随机访问 ...

  2. java:数据结构(二)栈的应用(括号匹配)

    一.什么是括号匹配: 括号匹配就是利用计算机辨别表达式里面的括号是否书写成功 例如: {()((a)) }这就是一个正确 (()()   这就是一个错误的 二.括号匹配的算法: 众所周知,括号分为花括 ...

  3. 自己动手实现java数据结构(二) 链表

    1.链表介绍 前面我们已经介绍了向量,向量是基于数组进行数据存储的线性表.今天,要介绍的是线性表的另一种实现方式---链表. 链表和向量都是线性表,从使用者的角度上依然被视为一个线性的列表结构.但是, ...

  4. java:数据结构(二)栈的应用(进制转换全收集)

    说到进制转换,java已经封装了基本的方法,在竞赛中使用封装的方法自然能节省大量时间 另一位仁兄介绍的封装好的方法: https://blog.csdn.net/m0_37961948/article ...

  5. java 数据结构(二):java常用类 二 StringBuffer、StringBuilder

    1.String.StringBuffer.StringBuilder三者的对比String:不可变的字符序列:底层使用char[]存储StringBuffer:可变的字符序列:线程安全的,效率低:底 ...

  6. 【算法与数据结构】二叉搜索树的Java实现

    为了更加深入了解二叉搜索树,博主自己用Java写了个二叉搜索树,有兴趣的同学可以一起探讨探讨. 首先,二叉搜索树是啥?它有什么用呢? 二叉搜索树, 也称二叉排序树,它的每个节点的数据结构为1个父节点指 ...

  7. 自己动手实现java数据结构(六)二叉搜索树

    1.二叉搜索树介绍 前面我们已经介绍过了向量和链表.有序向量可以以二分查找的方式高效的查找特定元素,而缺点是插入删除的效率较低(需要整体移动内部元素):链表的优点在于插入,删除元素时效率较高,但由于不 ...

  8. 【Java数据结构学习笔记之二】Java数据结构与算法之栈(Stack)实现

      本篇是java数据结构与算法的第2篇,从本篇开始我们将来了解栈的设计与实现,以下是本篇的相关知识点: 栈的抽象数据类型 顺序栈的设计与实现 链式栈的设计与实现 栈的应用 栈的抽象数据类型   栈是 ...

  9. Java数据结构和算法(二)顺序存储的树结构

    Java数据结构和算法(二)顺序存储的树结构 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 二叉树也可以用数组存储,可以和完 ...

随机推荐

  1. Roboguice学习之视图注入

    Robuguide的使用 准备工作: 首先在项目中必须实现GreetingModule和RoboguiceDemoApplication GreetingModule.java import com. ...

  2. CodeForces 383D Antimatter

    线性DP. dp[i][j]表示以第i个数字为结尾的,字串和为j的有几种. #include<cstdio> #include<cstring> #include<cma ...

  3. MFC添加背景图片三种方法

    方法一: 1.声明成员变量CBrush m_brush;2.在InitDialog中添加代码: ? CBitmap bmp; bmp.LoadBitmap(IDB_BITMAP1);  //IDB_B ...

  4. C语言中的几种常见排序算法

    1.冒泡排序法:如果有N个数,两两相邻进行比较,将最值沉入最后一位置,要进行N-1轮比较, 第一轮要比较N-1次,第2轮只要比较N-1-1次,因为第一次已经把最值沉入最后一位置,故 不需在进行比较一次 ...

  5. 零成本实现Android/iOS自动化测试:基于Appium和Test Perfect

    https://item.taobao.com/item.htm?spm=a230r.1.14.14.42KJ3L&id=527677900735&ns=1&abbucket= ...

  6. MFC的核心概念

    API是英文Application Programming Interface 的缩写,意思是“应用程序接口”,泛指系统为应用程序提供的一系列函数接口,在编程时可以直接调用,而不必知道其内部实现的过程 ...

  7. 移动WEB开发资源

    很多移动开发的资源 http://www.cnblogs.com/PeunZhang/p/3407453.html

  8. dyld: Symbol not found: _OBJC_CLASS_$_UIBlurEffect

    信息如下: 不知道为撒出现这个问题,查资料也木有查到..看提示信息可能是UIKit的问题,所以就试着这样解决,结果居然好了....有谁知道原因的告诉额一声啊,拜托!

  9. HDU1425 <sort 快排>

    给你n个整数,请按从大到小的顺序输出其中前m大的数. 每组测试数据有两行,第一行有两个数n,m(0<n,m<1000000),第二行包含n个各不相同,且都处于区间[-500000,5000 ...

  10. PAT (Advanced Level) 1059. Prime Factors (25)

    素因子分解. #include<iostream> #include<cstring> #include<cmath> #include<algorithm& ...