day14集合中的map系列(hashset,treeset)

翻译 2016年08月30日 12:07:44
import java.util.*;


/*
往hashSet集合中存入自定义对象
姓名和年龄相同为同一人,重复元素


*/
class HashSetTest
{
public static void sop(Object obj)
{
System.out.println(obj);
}

public static void main(String[] args) 
{
HashSet hs=new HashSet();


hs.add(new Person("a1",11));
hs.add(new Person("a2",12));
hs.add(new Person("a3",13));
hs.add(new Person("a4",14));


Iterator it=hs.iterator();


while (it.hasNext())
{
Person p=(Person)it.next();
sop(p.getName()+"....."+p.getAge());
}


}
}
class Person
{
private String name;
private int age;
Person(String name,int age)
{
this.name=name;
this.age=age;
}
public int hashCode()
{
return name.hashCode()+age;
}
public boolean equals(Object obj)
{
if (!(obj instanceof Person))
{
return false;
}
Person p=(Person) obj;


return this.name.equals(p.name)&&this.age==p.age;
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}

}

----------------------------

import java.util.*;
import java.lang.Comparable;
/*


需求:
往treeset集合中存储自定义对象学生。
想按照学生的年龄进行排序。

TreeSet第一种方式
*/
class TreeSetDemo 
{
public static void main(String[] args) 
{
TreeSet ts=new TreeSet();


ts.add(new Student("lisi02",22));
ts.add(new Student("lisi007",20));
ts.add(new Student("lisi09",19));
ts.add(new Student("lisi01",40));

Iterator it=ts.iterator();
while(it.hasNext()) 
{
Student stu=(Student)it.next();
System.out.println(stu.getName()+"..."+stu.getAge());
}
}

}

class Student implements Comparable
{
private String name;
private int age;
Student(String name,int age)
{
this.name=name;
this.age=age;
}
public int compareTo(Object obj)
{
//return 0;1-1
if(!(obj instanceof Student))
throw new RuntimeException("不是学生对象");

Student s=(Student)obj;
if (this.age>s.age) 
return 1;
if (this.age==s.age)
{
return 0;
}
return -1;
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}
} //该接口强制让学生具有比较性

-----------------------------------

import java.util.*;
/*
TreeSet第二种方式
*/
class Student implements Comparable
{
private String name;
private int age;
Student(String name,int age)
{
this.name=name;
this.age=age;
}
public int compareTo(Object obj)
{
//return 0;1-1
if(!(obj instanceof Student))
throw new RuntimeException("不是学生对象");


Student   s= (Student)obj;


if (this.age>s.age)
return 1;
if (this.age==s.age)
{
return this.name.compareTo(s.name);
}
return -1;
}


public String getName()
{
return name;
}


public int getAge()
{
return age;
}
}

class TreeSetDemo2 
{
public static void main(String[] args) 
{
TreeSet ts=new TreeSet();

ts.add(new Student("lisi02",22));
ts.add(new Student("lisi007",20));
ts.add(new Student("lisi09",19));
ts.add(new Student("lisi01",40));

Iterator it=ts.iterator();
while(it.hasNext()) 
{
Student stu=(Student)it.next();
System.out.println(stu.getName()+"..."+stu.getAge());
}
}
}
class MyCompare implements Comparator
{
public int compare(Object o1,Object o2)
{
Student s1=(Student)o1;
Student s2=(Student)o2;
int num=s1.getName().compareTo(s2.getName());
if (num==0)
{
new Integer(s1.getAge()).compareTo(new Integer(s2.getAge()));
/*if(s1.getAge()>s2.getAge())
return 1;
if(s1.getAge()==s2.getAge())
return 0;
return -1;*/
}
return num;
}
}

相关文章推荐

黑马程序员_JAVA笔记14——集合框架(List、HashSet、TreeSet)

------- android培训、java培训、期待与您交流! ---------- 1、为什么出现集合类,面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行存储...

day09 集合 list Arraryist LinkedList Vector HashSet treeSet comparable Iterator 如有错多多指教

集合 •Java的集合类是一种特别有用的工具类,用于存储数量不等的多个对象,所以称为容器类(所有集合类都位于java.util包下。) •Java集合体系:   1.Set:无序、不可重复的集合 ...

Java集合框架(Set与Map,HashSet与HashMap,TreeSet与TreeMap)

定义

Java集合Set、Map、HashSet、HashMap、TreeSet、TreeMap等

1、Set和Map的关系: Set代表一种集合元素无序、不可重复的集合,Map代表一种由多个key-value对组成的集合。 Set的集合继承体系: Map关系集合 Map集合的key特征:所有k...

集合二:Set、HashSet、TreeSet、Map、HashMap、TreeMap

-------android培训、Java培训、期待与您交流!------- 1  Set集合 1.1  Set集合概述 Set集合的元素是无序的,即存入的顺序和取出的顺序不一定是一致的。 Set...

Java 集合系列之 Set架构 TreeSet HashSet 详细介绍(源码解析)和使用示例

Java 集合系列之 Set架构 TreeSet HashSet 详细介绍(源码解析)和使用示例

java集合系列——Set之HashSet和TreeSet介绍(十)

Set是一个不包含重复元素的 collection。更确切地讲,set 不包含满足 e1.equals(e2) 的元素。对 e1 和 e2,并且最多包含一个为 null 的元素。

黑马程序员_day14 集合(迭代器,Vector中的枚举,LinkedList,HashSet)

---------------------- android培训、java培训 期待与您交流! ---------------------- 一:集合类。  1,为什么出现集合类? 答:面向对象语...

HashSet、LinkedHashSet、TreeSet+JAVA学习笔记-DAY17

HashSet存储字符串并遍历)

day17(HashSet,TreeSet)

一.HashSet1.Set集合*一个不包含重复元素的 collection,且无顺序 2.HashSet存储自定义对象保证元素唯一性public class temp2 { public s...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)