ArrayList sort和Interator用法
来源:互联网 发布:hadoop 数据清洗工具 编辑:程序博客网 时间:2024/06/08 17:00
ArrayList sort 用法
项目中曾经用到比较复杂的Comparator来进行排序,当时一直不大明白其中的原理,今天就来分析一下。
1、Sort
1.1、数组运用sort(例如,sort(Cah))
//数组的定义 char[] ch = new char[20]; String s= "546312"; ch=s.toCharArray(); Arrays.sort(ch); System.out.println(ch);
输出结果展示: 123456
1.2数组sort通过comparator实现 降序处理
public class ArrayTest1 { public static void main(String args[]){ //示例2 Count c1 = new Count(1); Count c2 = new Count(2); Count c3 = new Count(3); Count[] cArr = {c1,c2,c3}; Arrays.sort(cArr, new Comparator<Count>(){ @Override public int compare(Count o1, Count o2) { // TODO Auto-generated method stub return o2.value - o1.value; } }); for(int i =0;i<cArr.length;i++){ System.out.println(cArr[i].value); } }}class Count{ int value; public Count(int param){ value = param; }}
输出结果为:
321
2、ArrayList 排序
ArrayList中的元素进行排序,主要考查的是对util包中的Comparator接口和Collections类的使用。
实现Comparator接口必须实现compare方法,自己可以去看API帮助文档。
创建一个Comparator实例后,可用Collections.sort(List,Comparator)对List中的元素进行排序。也可用定义的arrayList 实例(如arrList.sort(Comparator))
以下示例用到ArrayList中Map中的key值排序
public class ArrayListTest { public static void main(String args[]) { List<Map<String, Object>> arrList = new ArrayList<>(); Map<String, Object> item = new HashMap<String, Object>(); item.put("1A", "this is 1A -->4"); arrList.add(item); item = new HashMap<String, Object>(); item.put("1B", "this is 1B -->3"); arrList.add(item); item = new HashMap<String, Object>(); item.put("2B", "this is 2B -->1"); arrList.add(item); item = new HashMap<String, Object>(); item.put("2A", "this is 2A -->2"); arrList.add(item); arrList.sort(new Comparator<Map<String, Object>>() { @Override public int compare(Map<String, Object> o1, Map<String, Object> o2) { // 定义比较的大小关系 int temp1 = setResult(o1); int temp2 = setResult(o2); return temp1 - temp2; } private int setResult(Map<String, Object> map) { Iterator<String> iter = map.keySet().iterator(); String temp = iter.next(); switch (temp) { case "1A": return 4; case "1B": return 3; case "2A": return 2; case "2B": return 1; default: return 0; } } }); for(Map<String, Object> str :arrList){ System.out.println(str.toString()); } }}
输出结果:
{2B=this is 2B -->1}{2A=this is 2A -->2}{1B=this is 1B -->3}{1A=this is 1A -->4}
上述代码,根据Map中key值排序,如果需要按照value值排序,使用map.entrySet() 获取值的集合,同样可根据Iterator 遍历
Iterator
上面的代码中,set集合使用的就是Iterator 遍历,同样的用法也适用于ArrayList
Java中的Iterator功能比较简单,并且只能单向移动:
(1) 使用方法iterator()要求容器返回一个Iterator。第一次调用Iterator的next()方法时,它返回序列的第一个元素。注意:iterator()方法是java.lang.Iterable接口,被Collection继承。
(2) 使用next()获得序列中的下一个元素。
(3) 使用hasNext()检查序列中是否还有元素。
(4) 使用remove()将迭代器新返回的元素删除。
import java.util.ArrayList;import java.util.Iterator;public class IteratorTest { public static void main(String args[]){ ArrayList list = new ArrayList(); list.add(1); list.add(2); list.add(3); list.add(4); Iterator iter = list.iterator(); while(iter.hasNext()){ Integer temp = (Integer) iter.next(); if(temp==2){ iter.remove(); continue; } System.out.println(temp); } }}
输出结果:
134
通过示例应该可以更清楚的了解到Iterator 用法
阅读全文
0 0
- ArrayList sort和Interator用法
- C# Arraylist的sort函数的用法
- sort()和stable_sort()用法
- sort--ArrayList
- ArrayList.Sort()
- java数组和ArrayList用法
- ArrayList 和 List<T>用法
- ArrayList和HashMap常见用法
- ArrayList和LinkedList的用法
- sort和qsort用法总结
- sort() 和 qsort() 用法详解
- qsort和sort的用法
- sort和qsort的用法
- qsort和sort的用法
- Java Sort Arraylist
- How to Sort Arraylist
- ArrayList排序sort()方法
- C#ArrayList-sort
- ZOJ1160 Biorhythms【中国剩余定理】
- akka之RPC通信1
- Android AIDL使用详解
- 魔术
- STM32F4 HAL库DMA学习
- ArrayList sort和Interator用法
- cocos2dx 植物大战僵尸 23 撑杆僵尸
- C语言中qsort函数用法详解
- FPGA时钟设置处理方法
- [LeetCode] 78. Subsets
- netcat很强大
- macOS开发中NSWindow, NSWindowController, NSView, NSViewController的关系
- JDK之Iterator
- 如何解决npm should be run outside of the node repl,in your normal shell