package com.net.xinfang.reflect;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.LinkedList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set; /***
* 集合类(List-LinkedList/ArrayList/Vector,Set,Map-HashTable/HashMap)
*
* @author xinfang
*
*/
public class collect004 {
public void map() {
Map map = new HashMap();
map.put("key1", "lisi1");
map.put("key2", "lisi2");
// 先获取map集合的所有键的set集合,keyset()
Iterator it = map.keySet().iterator();
// 获取迭代器
// 第一种遍历Iterator-keySet
while (it.hasNext()) {
Object key = it.next();
System.out.println(map.get(key));
}
// 第二种遍历(推荐,效率高)-entrySet
// 将map集合中的映射关系取出,存入到set集合
Iterator it1 = map.entrySet().iterator();// 创建迭代对象
while (it1.hasNext()) {// hasNext判断是否还有下一个元素
Entry e = (Entry) it1.next();
System.out.println("键" + e.getKey() + "的值为" + e.getValue());
}
// foreach遍历方式-keySet
Map<String, Integer> ma = new HashMap<String, Integer>();
ma.put("二阳", 23);
ma.put("二峥", 24);
Set<String> keys = ma.keySet(); // 把键其中起来,存入到set集合中.
for (String key : keys) { // 遍历键集合,获取每一个键
Integer value = ma.get(key); // 让键去找值 get(Object key)
System.out.println(key + "***" + value);
}
// entrySet
Set<Map.Entry<String, Integer>> set = ma.entrySet();
for (Map.Entry<String, Integer> me : set) { // 遍历键值对集合,获取到每一个键值对。增强for,迭代器
String key = me.getKey(); // 通过键值对获取键getKey()
Integer value = me.getValue(); // 通过键值对获取值getValue()
System.out.println(key + "***" + value);
}
} public void List() {
List<String> strList = new ArrayList<>();// 动态数组-get/set快
List<String> linkList = new LinkedList<>();// 链表-插入/删除快
//ArrayList<String> ast=new ArrayList<>();
//LinkedList<String> list=new LinkedList<>();
linkList.add("2");
linkList.add("1");
linkList.add("1");
strList.add("1");// 添加元素
strList.add("2");
strList.toString();// 转换字符串
strList.size();// 获取长度
strList.get(0);// 获取索引为0的值
strList.remove(0);// 移除索引为0的值
Collections.sort(linkList);// 排序
removeDuplicate(linkList);// 去重
strList.contains("1");// 判断是否包含1
strList.set(0, "1");// 替换索引为0的值
strList.add(1, "2");// 添加索引为1的值
strList.indexOf("1");// 获取第一个出现1的索引位置
strList.lastIndexOf("2");// 获取最后一个出现2的索引位置
strList.subList(0, 1);// 截取0<=index<1的值作为新的List
// equals值比较相等,hashcode相等的对象就不一定是相等的对象
strList.isEmpty();// 空为true,非空为false
strList.iterator();// 返回iterator集合对象
// for循环方式遍历
for (int i = 0; i < strList.size(); i++) {
System.out.println(strList.get(i));
}
// foreach遍历list
for (String obj : strList) {
System.out.println(obj);
}
for (String obj : linkList) {
System.out.println(obj);
}
// Iterator接口迭代遍历
Iterator<String> it = strList.iterator();
while (it.hasNext()) {
String obj = it.next();
System.out.println(obj);
}
// List转换为数组
// 第一种for循环转换
String string[] = new String[strList.size()];
for (int i = 0, j = strList.size(); i < j; i++) {
string[i] = strList.get(i);
}
// 第二种调用toArray函数转换
String[] strings = new String[strList.size()];
strList.toArray(strings);
for (String str : strings) {
System.out.println(str);
}
// 数组转换为List
String[] s = { "a", "b", "c" };
List<String> list = new ArrayList<>(Arrays.asList(s));
for (String st : list) {
System.out.println(st);
}
} // 利用HashSet特性去重
public static void removeDuplicate(List list) {
HashSet h = new HashSet(list);
list.clear();
list.addAll(h);
System.out.println(list);
} // 前者与后者比较去重
public static void removeDuplicate1(List list) {
for (int i = 0; i < list.size() - 1; i++) {
for (int j = list.size() - 1; j > i; j--) {
if (list.get(j).equals(list.get(i))) {
list.remove(j);
}
}
}
System.out.println(list);
} public void list1() {
String a = "A", b = "B", c = "C", d = "D", e = "E";// 定义要插入集合的字符串对象
List<String> list = new LinkedList<String>();// 创建List集合
list.add(a);// 向集合中添加元素
list.add(b);
list.add(c);
Iterator<String> iter = list.iterator();// 创建集合的迭代器
System.out.println("修改后 前集合 中的元素是:");
while (iter.hasNext()) {
System.out.print(iter.next() + " ");
}
list.set(0, e);// 将索引位置为0的对象修改为对象e
list.set(2, d);// 将索引位置为2的对象修改为对象d
Iterator<String> it = list.iterator();// 创建将集合对象修改后的迭代器对象
System.out.println();
System.out.println("修改后的集合中的元素是:");
while (it.hasNext()) {// 循环获取集合中的元素
System.out.print(it.next() + " ");
}
List list1 = new ArrayList();// 创建集合对象
int i = (int) (Math.random() * (list.size() - 1));// 获得0-2之间的随机数
list1.add("a");// 向集合中添加元素
list1.add("b");
list1.add("c");
System.out.println("随机获取数组中的元素:" + list1.get(i));//
list1.remove(2);// 将指定索引位置的元素从集合中移除
System.out.println("将索引是'2'的元素从数组中移除后,数组中的元素是:");
for (int j = 0; j < list1.size(); j++) {// 循环遍历数组
System.out.print(list1.get(j) + " ");
}
} public static void main(String args[]) {
collect004 c1 = new collect004();
c1.map();
c1.List();
c1.list1();
// 冒泡排序
/***
* 基本思想:在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。
* 即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换。
*/
int[] a = { 1, 3, 2 };
for (int i = 0; i < a.length; i++) {
for (int j = 0; j < a.length - 1 - i; j++) {
if (a[j] > a[j + 1]) {
int temp = a[j + 1];
a[j + 1] = a[j];
a[j] = temp;
}
}
}
for (int k : a) {
System.out.println(k);
}
int arr[] = { 23, 12, 6 };
// 冒泡排序(比较相邻的两个元素,大的往后排,小的往前移动,第一层循环避免漏排,第二层循环比较排序)
for (int i = 0; i < arr.length - 1; i++) {
for (int j = 0; j < arr.length - 1; j++) {
if (arr[j] > arr[j + 1]) {
int t = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = t;
}
}
}
for (int k : arr) {
System.out.println(k);
}
/***
* 选择排序-比较第一个与第二个,以此类推,大的往后移,小的往前移 冒泡排序-相邻的比较,大的往后移,小的往前移
* 快速排序-选择第一个或最后一个元素作为基准元素, 第一趟扫描分为两部分(一部分为比基准元素小的,一部分比基准元素大的),然后分别递归排序
* 插入排序-选择一个记录元素,比较后排序插入新的数组
*/
//插入排序
int brr[] = {2, 3, 1, 5};
int i, j, insertNote;// 要插入的数据
for (i = 1; i < brr.length; i++) {// 从数组的第二个元素开始循环将数组中的元素插入
insertNote = brr[i];// 设置数组中的第2个元素为第一次循环要插入的数据
j = i - 1;
while (j >= 0 && insertNote < brr[j]) {
brr[j + 1] = brr[j];// 如果要插入的元素小于第j个元素,就将第j个元素向后移动
j--;
}
brr[j + 1] = insertNote;// 直到要插入的元素不小于第j个元素,将insertNote插入到数组中
}
for (int k : brr) {
System.out.println(k);
}
}
}

JAVA-集合类型List(ArrayList、LinkedList)常用操作例子(基础必备)的更多相关文章

  1. Java——集合框架之ArrayList,LinkedList,迭代器Iterator

    概述--集合框架 Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(具体实现接口的类).所有抽象出来的数据结构和操作(算法)统称为Java集合框架(Java Collection ...

  2. java-map复合类型(HashMap-TreeMap)常用操作例子(适合初学者)

    package com.net.xinfang.reflect; import java.util.ArrayList; import java.util.HashMap; import java.u ...

  3. Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例

    java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...

  4. JAVA集合类型(二)

    JAVA集合类型 (现代的变量集群) watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0J ...

  5. Java集合框架之ArrayList浅析

    Java集合框架之ArrayList浅析 一.ArrayList综述: 位于java.util包下的ArrayList是java集合框架的重要成员,它就是传说中的动态数组,用MSDN中的说法,就是Ar ...

  6. Java 集合 JDK1.7的LinkedList

    Java 集合 JDK1.7的LinkedList @author ixenos LinkedList LinkedList是List接口的双向链表实现,JDK1.7以前是双向循环链表,以后是双向非循 ...

  7. java集合系列之ArrayList源码分析

    java集合系列之ArrayList源码分析(基于jdk1.8) ArrayList简介 ArrayList时List接口的一个非常重要的实现子类,它的底层是通过动态数组实现的,因此它具备查询速度快, ...

  8. java集合类型源码解析之ArrayList

    前言 作为一个老码农,不仅要谈架构.谈并发,也不能忘记最基础的语言和数据结构,因此特开辟这个系列的文章,争取每个月写1~2篇关于java基础知识的文章,以温故而知新. 如无特别之处,这个系列文章所使用 ...

  9. Java集合 之List(ArrayList、LinkedList、Vector、Stack)理解(new)

    一. ArrayList底层实现原理 对比 和Vector不同,ArrayList中的操作不是线程安全的!所以,建议在单线程中才使用ArrayList,而在多线程中可以选择Vector或者CopyOn ...

随机推荐

  1. Outsider(HNOI2019)

    这不是一篇退役记,因为NOIP2018之后就写完了. Day-1 清明时节雨纷纷. 最后的时光,应该是怎么样的呢? 是像水滴一样,悄无声息地从指缝中溜走 还是如火焰一般,燃烧着最后的留恋? 晚上一直在 ...

  2. BZOJ1095 [ZJOI2007] Hide 捉迷藏 (括号序列 + 线段树)

    题意 给你一颗有 \(n\) 个点的树 , 共有 \(m\) 次操作 有两种类别qwq 将树上一个点染黑/白; 询问树上最远的两个黑点的距离. \((n \le 200000, m ≤500000)\ ...

  3. nfs的配置文件/etc/exports

    /etc/exports  文件格式 <输出目录> [客户端1 选项(访问权限,用户映射,其他)] [客户端2 选项(访问权限,用户映射,其他)] a. 输出目录:输出目录是指NFS系统中 ...

  4. rt-thread中线程内置定时器的作用 ---

    @2019-01-15 [小记] 常见到在内核组件的接口函数中,配置和启动一个定时器后,启动线程调度 我猜想是超时时间到达后恢复调用接口函数的线程以执行线程调度语句后的代码

  5. 【bfs】献给阿尔吉侬的花束

    [题目描述] 阿尔吉侬是一只聪明又慵懒的小白鼠,它最擅长的就是走各种各样的迷宫.今天它要挑战一个非常大的迷宫,研究员们为了鼓励阿尔吉侬尽快到达终点,就在终点放了一块阿尔吉侬最喜欢的奶酪.现在研究员们想 ...

  6. 部署KVM

    1.安装前准备1)服务器或者PC的CPU能支持VT技术2)虚拟机中安装KVM要勾选:处理器:虚拟化Intel VT-x/EPT或AMD-V/RVI(V)[root@localhost ~]# cat ...

  7. centos7下利用httpd2.4配置svn并使用Ldap用户认证

    应用场景:Windows下有AD活动目录,类Unix系统下有Ldap,在运维开发工具平台逐步丰富的现在,统一用户管理大大便捷了管理人员. 其中不乏经典版本控制管理工具svn,与Ldap组合的用户认证方 ...

  8. Spring Boot实战

    Spring在java EE开发中是实际意义上的标准,但我们在开发Spring的时候可能会遇到以下令人头疼的问题: 1.大量配置文件的定义.2.与第三方软件整合的技术问题. Spring每个版本的退出 ...

  9. A1141. PAT Ranking of Institutions

    After each PAT, the PAT Center will announce the ranking of institutions based on their students' pe ...

  10. 【CF1141G】Privatization of Roads in Treeland

    题目大意:给定一个 N 个点的无根树,现给这个树进行染色.定义一个节点是坏点,若满足与该节点相连的至少两条边是相同的颜色,求至多有 k 个坏点的情况下最少需要几种颜色才能进行合法染色. 题解:考虑一个 ...