Java的集合可以分为两类,

第一类是以数组为代表,这类集合可以描述线性表类型的数据结构,以Collection为基类,其中自己用过或者了解的有

实现List接口的类:LinkedList,ArrayList,Vector,Stack...

实现Set接口的类:TreeSet,HashSet...

第二类是以Map为代表的“键值对”类型的数据结构,以Map为基类,其中有

HashMap,HashTable,Tree

第一类

Vector

Vector与数组相比,Vector对象可以很好的实现元素的插入和删除,也拥有动态增长特性

1.构造函数(4)

  • Vector()
  • Vector(<E> c)使用泛型(generic type)确定容纳对象的类型
  • Vector(int initialCapacity,int capacityIncrement)

  能为初始化的Vector对象分配长度为initialCapacity的容量,可以在必要的时候以capacityIncrement的速度自增长其容量空间

  • Vector(int initialCapacity)

2.常用方法

  • addElement(E obj)向Vector中添加元素

  通过这个方法可把obj对象添加到该Vector对象的尾部,同时Vector的size加1。

  • insertElementAt(E obj)在指定索引处添加元素

  通过这个方法,可以把obj对象添加到参数指定的index索引处,此后的Vector对象里的各内容自动向后移动一个单位

  setElement(E obj,int index)替换指定位置的元素

  • boolean removeElement(Object obj)删除Vector对象中的第一个obj对象,返回一个bool类型的值用来表示是否找到并删除指定对象
  • void removeElementAt(int index)删除指定位置的元素
  • void removeAllElements()删除Vector对象中的所有元素,size置为0
  • int size()获得Vector当前长度
 /*
*@author SimonKly E-mail:deGaulleKong@gmail.com
*@version:2017-2-25
*/
import java.util.Vector;
public class VectorTest {
public static void main(String[] args) {
// 实例一个Vector对象
Vector v=new Vector();
// 向Vector对象中添加元素
v.addElement(new Integer(1));
v.addElement("two");
v.addElement("Three");
// 向Vector对象指定位置插入
v.insertElementAt(0, 0);
// 替换指定位置的元素
v.setElementAt("four",3);
// 遍历Vector对象
System.out.print("element :");
for(int i=0;i<v.size();i++){
if(v.elementAt(i) instanceof Integer)//判断元素类型
System.out.print(" "+((Integer)v.elementAt(i)));
else
System.out.print(" "+(String)v.elementAt(i));
} System.out.println();
// 删除指定位置的元素
v.removeElementAt(3);
System.out.print("element :");
// 遍历验证
for(int i=0;i<v.size();i++){
if(v.elementAt(i) instanceof Integer)
System.out.print(" "+((Integer)v.elementAt(i)));
else
System.out.print(" "+(String)v.elementAt(i));
}
System.out.println();
// 删除所有元素
v.removeAllElements();
if(v.size()==0){
System.out.println("Cleared!");
}
}
}

Stack

Stack继承了Vector,Stack重用 了Vector的存储对象空间和访问线性表方法,而Stack先进后出的特性可以看作Vector的特例

1.构造函数

  • Stack()
  • Stack(<E s>)

2.常用方法

  • E push(E item)向堆栈中压入item,并将item对象返回
  • E peek()返回指定栈顶元素的类型
  • E pop()弹出栈顶元素
  • boolean empty()判断堆栈是否为空
 package $1;

 /**
*@author: SimonKly
*@E-mail:deGaulleKong@gmail.com
*@date: 2017年2月27日
*/ import java.util.Iterator;
import java.util.Stack; public class StackTest { public static void main(String[] args) {
Stack s=new Stack();
s.push("one");
s.push("two");
s.push("three");
Iterator iterator=s.iterator();
System.out.println("iterator:");
while(iterator.hasNext()){
System.out.println(iterator.next());
}
System.out.println("normal:");
for(int i=0;i<s.size();i++){
System.out.println(s.get(i));
}
System.out.println("pop");
while(!s.isEmpty()){
System.out.println(s.pop());
}
//由于继承了Vector则,不好用法则会Stack把当成Vector
s.addElement("badusage1");
s.addElement("badusage2");
s.addElement("badusage3");
for(int i=0;i<s.size();i++){
System.out.println(s.elementAt(i));
}
} }

List接口

Vector和Stack都实现了List接口

其中的方法

  • 插入

    void add(int index,E element)在索引号index后插入element元素

    boolean add(E o)直接插入到链表的最后

  • 删除

    E remove(int index)删除链表中指定的位置

    boolean remove(Object o)删除链表中第一个元素

  • 获取元素

    E get(int index)获取指定位置的元素

int size()统计有多少元素

int indexOf(Object obj)获取obj对象的索引位置

List<E>subList(int fromIndex,int to Index)截取链表,得到链表里的从fromindex开始到toIndex结束的子链表

void clear()清空链表

LinkedList实现了List

1.构造函数

LinkedList()

LinkedList(Collection c)

LinkedList(<E> c)

2.添加元素

void addFirst(E obj)//添加头元素

void addLast(E obj)//添加尾元素

3.获取元素

E getFirst()//获取第一个

E getLast()//获取最后一个

4.删除元素

E removeFirst()//删除第一个并返回第一个元素

E removeLast()//删除最后一个并返回最后一个元素

 package $1;

 /**
*@author: SimonKly
*@E-mail:degaullekong@gmail.com
*@date: 2017年2月27日
*/
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
public class LinkedListTest { public static void main(String[] args) {
// 使用泛型实例化一个LinkedList对象
List<String>ll=new LinkedList<String>();
// 向LinkedList中添加元素
ll.add("one");
ll.add("two");
ll.add("three");
// 不使用泛型实例化一个LinkedList对象
List l=new LinkedList();
l.add("first");
l.add("second");
l.add(3);//可以放入不同的数据类型
// 打印指定位置的元素
System.out.println("the index of 3:"+l.indexOf(3));
// 移除指定位置的元素
ll.remove(2);
// 使用Iterator对象遍历
Iterator iterator=ll.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
// 使用一般遍历方法遍历
for(int index=0;index<l.size();index++){
System.out.println(l.get(index));
}
}
}

不允许有重复元素的Set接口

接口中的方法:

1.添加元素:boolean add(E o)用到泛型,如果待插入的元素不在Set中则返回true,反之,返回false

2.删除指定元素:boolean remove(Object o)如果找到并成功删除则返回true ,反之,返回false

3.判断Set是否为空:boolean isEmpty()

4.返回Set大小的Size();

实现的类有HashSet,TreeSet(输出是有序)

第二类

HashTable

1.构造函数

HashTable()//初始容量为11,默认装载因子0.75

HashTable(int initialCapacity)//初始化容量,默认装载因子0.75

HashTable(int initialCapacity,float loadFactor)//初始化容量和装载因子

HashTable(<K,V>t)//使用泛型

2.添加键值

put(K key ,V value)

3.根据键值获取值

V get(Object key)

4.判断“键”和“值”是否存在

boolean containsKey(Object key)

boolean containsValue(Object value)

封装散列表数据结构的Map接口,实现的类:HashMap和TreeMap

其中方法:

1.V put(K key,V value)插入键值对,并返回value

2.V get(Object key)

3.boolean containsKey(Object key) boolean containsValue(Object value)判断是否存在键或者值

4.Set<Map.Entry<K,V>> entrySet()//返回键值对映射关系,用于遍历

 package $2;
/**
*@author: SimonKly
*@E-mail:degaullekong@gmail.com
*@date: 2017年2月27日
*/
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.TreeMap; public class MapTest {
static void prt(Map m)
{
Iterator i=m.keySet().iterator();
while(i.hasNext()){
Object o=i.next();
System.out.println("key="+o+",value="+m.get(o));
}
}
public static void main(String[] args) {
Map m; System.out.println("HashMap例子:");
m=new HashMap();
m.put(1, "one");
m.put(2, "two");
m.put(3, "three");
m.put(4, "four");
MapTest.prt(m); System.out.println("TreeMap例子:");
m=new TreeMap();
m.put(3, "three");
m.put(4,"four");
m.put(1, "one");
m.put(2, "two");
MapTest.prt(m);
// 使用Entry对象遍历Map
System.out.println("Entry对象遍历Map:");
HashMap<Integer,String> em=new HashMap<Integer,String>();
em.put(3, "three");
em.put(4,"four");
em.put(1, "one");
em.put(2, "two");
// 使用Entry对象遍历
for(Entry<Integer,String> entry:em.entrySet())
{
System.out.println("key="+entry.getKey()+",value="+entry.getValue());
}
}
}

Java数据结构----集合的更多相关文章

  1. (7)Java数据结构--集合map,set,list详解

    MAP,SET,LIST,等JAVA中集合解析(了解) - clam_clam的专栏 - CSDN博---有颜色, http://blog.csdn.net/clam_clam/article/det ...

  2. Java.数据结构.集合体系详解

    I. 第一部分:常见数据结构 首先简单说下数据结构. 什么是数据结构?数据结构就是组织数据的方式. 常见的数据结构:栈,堆,树,图,数组,队列,链表. 这里主要介绍与java集合体系相关的栈.数组和链 ...

  3. 【Java】集合_学习笔记

    一.集合 1.集合类也称容器类,主要负责保存.盛装其他数据. 2.集合可以保存数量不确定的数据,保存具有映射关系的数据(也称关联数组). 3.Java5后提供一些多线程安全的集合类,放在java.ut ...

  4. java的集合框架最全详解

    java的集合框架最全详解(图) 前言:数据结构对程序设计有着深远的影响,在面向过程的C语言中,数据库结构用struct来描述,而在面向对象的编程中,数据结构是用类来描述的,并且包含有对该数据结构操作 ...

  5. 谈谈Java的集合组件

    让我们一起谈谈Java的集合组件 我们在使用Java的时候,都会遇到并使用到Java的集合.在这里通过自己的理解和网上的资源对Java的集合方面的使用做一个简单的讲解和总结. Java主要分为3个集合 ...

  6. Java数据结构之树和二叉树(2)

    从这里始将要继续进行Java数据结构的相关讲解,Are you ready?Let's go~~ Java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来 ...

  7. Java数据结构之树和二叉树

    从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ Java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...

  8. Java学习-集合(转)

    在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处充斥着集合类的身影!java中集合大家族的成员实在是太丰富了,有常用的ArrayList. ...

  9. java的集合框架之一

    java是一套很成熟的东西,很多商用的东西都喜欢用它,用的人多,稳定.不过一般也不怎么说起它,因为太常见了,私下里说,写java应用层得就像农民工,每一处都是搭积木,根据设计师的东西如何优雅地搭好积木 ...

随机推荐

  1. win10操作系统 64位 原版 百度网盘下载

    iso镜像文件4.57G,这里压缩成两个两个包便于上传网盘: 使用时候,直接下载两个压缩包解压成镜像文件便可安装: 链接:https://pan.baidu.com/s/1JNgxuBzdzFpp-p ...

  2. php错误提示

    1.配置php.ini打开php.ini,把display_errors = Off 改成 display_errors = On然后找到 error_reporting 最好设置成error_rep ...

  3. (转)图文详解MyEclipse中新建Maven webapp项目的步骤

    转:https://blog.csdn.net/ClementAD/article/details/46592557 MyEclipse中创建新的Maven项目(webapp目录结构)过程如下:   ...

  4. 2018icpc南京/gym101981 K Kangaroo Puzzle 随机化

    题意: 有一个棋盘上,1是空格,0是障碍物,一开始每个空格里都有一只袋鼠,你可以命令所有袋鼠一起向上下左右一个方向走一格,一旦碰到边界或障碍物,袋鼠就不动,如果它后面有袋鼠这两个袋鼠就会挤进一个格子, ...

  5. thinkphp 连接多个数据库

    config配置文件 //数据库配置信息 'DB_CONFIG' => array( 'DB_TYPE' => 'mysql', // 数据库类型 'DB_HOST' => 'loc ...

  6. 数据库的基本使用(C#语言)

    目录 insert select 的使用 delete update 更新 Like模糊查询 Order 排序 GETDATA() 聚合函数:MAX,MIN,AVG,SUM,COUNT Max COU ...

  7. docker 安装 lnmp

    docker 安装 lnmp 标签(空格分隔): php,docker 安装MySql 1 搜索镜像 docker search mysql 2 安装镜像 docker pull mysql:5.7 ...

  8. Django Model里的__str__以及Meta

    举个栗子,注释已经比较详细了 name = models.CharField(max_length=30,verbose_name='标签名称') #max_length=30里的30在mysql以前 ...

  9. 基于MFC的Media Player播放器的制作(2---导入第三方库和介绍第三方库)

    |   版权声明:本文为博主原创文章,未经博主允许不得转载. 这一节我们介绍如何导入类库,和介绍类库的一功能和介绍MFC的一些主要的模块部分.下面是如何导入类库.第一步我们选中 Media Playe ...

  10. 洛谷 P2024 [NOI2001]食物链——带权值的并查集维护

    先上一波题目 https://www.luogu.org/problem/P2024 通过这道题复习了一波并查集,学习了一波带权值操作 首先我们观察到 所有的环都是以A->B->C-> ...