SUMMARY | JAVA中的数据结构
String
- String类是不可修改的,创建需要修改的字符串需要使用StringBuffer(线程同步,安全性更高)或者StringBuilder(线程非同步,速度更快)。
- 可以用“+”连接String。
- 用String.format()创建格式化字符串。
ArrayList
- 动态数组,可以动态的增加或者减少元素。
- 常用操作:
- 创建:ArrayList<Type> arrayList=new ArrayList<>();
- 添加元素:add
- 获取元素:get
- 删除元素:remove
- 获取数组大小:size
- 判断是否包含某一元素:contains
- 设置元素:set
- 清空数组:clear
- 判断是否为空:isEmpty
- 遍历方式:通过下标索引效率最高
Type temp;
for(int i=0;i<arrayList.size();i++){
temp=arrayList.get(i);
}
- arrayList排序需要实现Comparator接口以实现自定义排序
Comparator<String> comparator=new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
if(o1.compareTo(o2)>0) return 1;
if(o1.compareTo(o2)<0) return -1;
return 0;
}
};
Stack
- 由vector拓展而来
- 常用操作:push,peak,pop,search,isEmpty
public static void stackTest() {
Stack<String> stack=new Stack<String>();
//将元素压入栈顶
System.out.println(stack.push("haha"));
System.out.println(stack.push("yes"));
//栈顶元素的search结果为1,然后从栈顶向栈底依次递增
System.out.println(stack.search("haha"));
//查看栈顶元素
System.out.println(stack.peek());
//弹出栈顶元素并返回栈顶元素
System.out.println(stack.pop());
//判断栈是否非空
System.out.println(stack.isEmpty());
}
Queue
- 是一个接口,LinkedList实现Queue接口
- 常用操作:offer,peek,poll,isEmpty
public static void queueTest() {
//LinkedList实现了Queue接口,所以构造时使用LinKedList
Queue<String> queue=new LinkedList<String>();
//在队列尾部增加元素,并返回是否增加成功
System.out.println(queue.offer("abc"));
System.out.println(queue.offer("def"));
//返回队首元素,若队列空,则返回null;(ps:element在队列空时抛出异常)
System.out.println(queue.peek());
//弹出队首元素,并返回队首元素,若队列空则返回null
System.out.println(queue.poll());
//判断队列是否空
System.out.println(queue.isEmpty());
}
LinkedList
- 双向链表,非同步
- 常用操作:addFirst,addLast,add,getFirst,getLast,get,removeFirst,removeLast,remove,isEmpty
public static void linkedlistTest() {
LinkedList<String> linkedList=new LinkedList<String>();
//在链表头部加,尾部加,任意位置加元素
linkedList.addFirst("haha");
linkedList.addLast("yali");
linkedList.add(1, "good");
//输出链表
System.out.println("first element:"+linkedList.getFirst());
System.out.println("last element:"+linkedList.getLast());
for(int i=0;i<linkedList.size();i++) System.out.println(linkedList.get(i));
//删除任意位置,头部,尾部的链表元素
linkedList.remove(1);
linkedList.removeFirst();
linkedList.removeLast();
//判断链表是否空
System.out.println(linkedList.isEmpty());
}
HashMap
- 非同步
public static void hashmapTest() {
HashMap<String, Integer> hashMap=new HashMap<String, Integer>();
//向哈希表中添加元素
hashMap.put("tp", 123);
hashMap.put("zp", 567);
System.out.println(hashMap);
//通过迭代器便利哈希表
for(Iterator<Entry<String, Integer>> iterator=hashMap.entrySet().iterator();iterator.hasNext();){
Entry<String, Integer> entry=iterator.next();
System.out.println(entry.getKey());
System.out.println(entry.getValue());
}
//查找哈希表中是否有该键
System.out.println(hashMap.containsKey("he"));
//查找哈希表是否有该值
System.out.println(hashMap.containsValue(567));
//删除哈希表中的键值对
hashMap.remove("tp");
System.out.println(hashMap);
}
SUMMARY | JAVA中的数据结构的更多相关文章
- java中的数据结构(集合|容器)
对java中的数据结构做一个小小的个人总结,虽然还没有到研究透彻jdk源码的地步.首先.java中为何需要集合的出现?什么需求导致.我想对于面向对象来说,对象适用于描述任何事物,所以为了方便对于对象的 ...
- [转]详细介绍java中的数据结构
详细介绍java中的数据结构 本文介绍的是java中的数据结构,本文试图通过简单的描述,向读者阐述各个类的作用以及如何正确使用这些类.一起来看本文吧! 也许你已经熟练使用了java.util包里面的各 ...
- 详细介绍java中的数据结构
详细介绍java中的数据结构 http://developer.51cto.com/art/201107/273003.htm 本文介绍的是java中的数据结构,本文试图通过简单的描述,向读者阐述各个 ...
- Java中的数据结构及排序算法
(明天补充) 主要是3种接口:List Set Map List:ArrayList,LinkedList:顺序表ArrayList,链表LinkedList,堆栈和队列可以使用LinkedList模 ...
- 动图+源码,演示Java中常用数据结构执行过程及原理
最近在整理数据结构方面的知识, 系统化看了下Java中常用数据结构, 突发奇想用动画来绘制数据流转过程. 主要基于jdk8, 可能会有些特性与jdk7之前不相同, 例如LinkedList Linke ...
- 动图+源码,演示 Java 中常用数据结构执行过程及原理
阅读本文大概需要 3.7 分钟. 作者:大道方圆 cnblogs.com/xdecode/p/9321848.html 最近在整理数据结构方面的知识, 系统化看了下Java中常用数据结构, 突发奇想 ...
- Java中的数据结构有哪些?HashMap的工作原理是什么?
Java中常用数据结构 常用的数据结构有哈希表,线性表,链表,java.util包中有三个重要的接口:List,Set,Map常用来实现基本的数据结构 HashMap的工作原理 HashMap基于ha ...
- Java中的数据结构-HashMap
Java数据结构-HashMap 目录 Java数据结构-HashMap 1. HashMap 1.1 HashMap介绍 1.1.1 HashMap介绍 1.1.2 HashMap继承图 1.2 H ...
- 18、Java中的 数据结构
Java2中引入了新的数据结构 集合框架 Collection,下一节再谈论(非常重要,面试也常问). 1.枚举 (Enumeration) 1.1 Enumeration 源码: public in ...
随机推荐
- BZOJ 2159: Crash 的文明世界(组合数学+第二类斯特林数+树形dp)
传送门 解题思路 比较有意思的一道数学题.首先\(n*k^2\)的做法比较好想,就是维护一个\(x^i\)这种东西,然后转移的时候用二项式定理拆开转移.然后有一个比较有意思的结论就是把求\(x^i\) ...
- NOIp2018集训test-9-6(pm)
T1T2是洛谷原题.Orz辉神290,被辉神吊起来打. 题 1 包裹快递 二分答案.这题似乎卡精度,不开long double二分500次都过不去. //Achen #include<algor ...
- NX二次开发-创建临时坐标系UF_CSYS_create_temp_csys
NX9+VS2012 #include <uf.h> #include <uf_csys.h> #include <uf_mtx.h> UF_initialize( ...
- Python入门 mac系统/linux系统 安装python (一)
mac 系统 在命令行里,不会用命令行就别学编程了,自行查一下怎么用吧 brew install python 如果没有brew这个命令: 在mac终端下执行 /usr/bin/ruby -e &qu ...
- Devstack单节点环境实战配置
本文为minxihou的翻译文章,转载请注明出处Bob Hou: http://blog.csdn.net/minxihou JmilkFan:minxihou的技术博文方向是 算法&Open ...
- 6.4 Data Types
Table 6-1 lists the size, representation, and range of each scalar data type for the C28x compiler. ...
- lasso数学解释
lasso:是L1正则化(绝对值) 注:坐标下降法即前向逐步线性回归 lasso算法:常用于特征选择 最小角算法,由于时间有限没有去好好研究(其实是有点复杂,尴尬)
- 自动化测试工具1-testcomplete
TestComplete是SmartBear公司开发的一套支持自动测试软件的工具.在当今的软件开发中,自动测试非常重要,大型软件开发公司很久以来就已经将其作为软件开发的一项重要环节.然而,自动测试软件 ...
- BAT大神推荐:看懂英文文档,每天只需要10分钟做这件事……
程序员这个行业是很特殊的.之所以说特殊,就是因为它所有的技术大多来自欧美,所以最主流,最新鲜,最正确的技术文章都是英文,遗憾的是,大部分还没有译本. 有些译文还比较差.与其等待别人的翻译,不如直接阅读 ...
- Eclipse中普通java项目转成Web项目
在eclipse导入一个myeclipse建的web项目后,在Eclipse中显示的还是java项目,按下面的步骤可以将其转换成web项目. 1.找到项目目录下的.project文件 2.编辑.pro ...