posts - 54,  comments - 1,  trackbacks - 0

JDK中提供的一个操作集合的工具:Collections,提供集对合对象的基本操作.

  • 复制:

Collections.copy(List des,List src);

将src中的元素复制到des中,des必须比src大,并且不能为空,否则出错.des中比src中多的元素将保持不变.

  • 排序:

static void sort(List elements)

static void sort(List elements, Comparator c)

Comparator 是一个排序器,可自定义的排序的方式(升,降)和比较值,如果不加此参数则按照升序(asc)对简单集合进行排序:Comparator.compare()对集合中相邻的两个元素进行比较,返回负数升序,正数降序.0不交换.

[例子]

class SortObj {
 
int i;

 String name;

 
public SortObj(int i, String name) {
  
this.i = i;
  
this.name = name;
 }

}


public class SortCollection {
 
public static void main(String[] args) {
  List list1 
= new ArrayList();

  list1.add(
new SortObj(5"name1"));
  list1.add(
new SortObj(3"name3"));
  list1.add(
new SortObj(1"name5"));
  list1.add(
new SortObj(4"name2"));
  list1.add(
new SortObj(2"name4"));

  System.
out.println("排序前: ");
  
for (int i = 0; i < list1.size(); i++{
   SortObj obj 
= (SortObj) list1.get(i);
   System.
out.println(obj.i + " " + obj.name);
  }

  Collections.sort(list1, 
new Comparator() {
   
public int compare(Object element1, Object element2) {
    SortObj item1 
= (SortObj) element1;
    SortObj item2 
= (SortObj) element2;
    
return item1.name.compareTo(item2.name);
   }

  }
);
  System.
out.println("排序后: ");
  
for (int i = 0; i < list1.size(); i++{
   SortObj obj 
= (SortObj) list1.get(i);
   System.
out.println(obj.i + " " + obj.name);
  }


 }

}


运行结果:

排序前:
5 name1
3 name3
1 name5
4 name2
2 name4

排序后:
5 name1
4 name2
3 name3
2 name4
1 name5

  • 简单算法

static Object min(Collection elements)

static Object max(Collection elements)

static Object min(Collection elements, Comparator c)

static Object max(Collection elements, Comparator c)

static void copy(List to, List from)

static void fill(List l, Object value)

static void replaceAll(List l,Object oldvalue, Object newvalue)

static int indexOfsubList(List l,List s)

static int lastingdexOfSubList(List l, List s)

static void reverse(List l)

static void rotate(List l, int d)

posted on 2005-08-22 23:42 ZhuJun 阅读(203) 评论(0)  编辑  收藏 所属分类: 开发手记

只有注册用户登录后才能发表评论。


网站导航:
 

蜀中人氏,躬耕于珠海

<2005年8月>
31123456
78910111213
14151617181920
21222324252627
28293031123
45678910

常用链接

留言簿(2)

随笔分类(71)

随笔档案(54)

博客

文档

站点

论坛

搜索

  •  

积分与排名

  • 积分 - 49833
  • 排名 - 982

最新评论

阅读排行榜