TECH_JAVAJAVA集合

3.6 Java 中的集合框架(下)(常用工具类)

2016-10-15  本文已影响46人  夏沫xx

1、学生选课-判断List中课程是否存在

思考:
1、在课程序列中,如何判断是否包含某门课或者某几门课程?
2、如果课程序列包含某门课程,如何判断该课程的索引位置?
3、在学生映射表中,如何判断是否包含某个学生ID?
4、又该如何判断是否包含某个学生对象?
5、如果想把课程或者学生对象,按照课程名称或者学生姓名排序又该怎么办?按照ID排序呢?

在某序列中,如何判断是否包含某元素,list、set都是从collection接口中继承来的contains方法(还有判断多个元素的containsAll)

/**
     * 测试List的contains方法
     */
    public void testListContains() {
        // 取得备选课程序列的第0个元素
        Course course = coursesToSelect.get(0);
        // 打印输出coursesToSelected是否包含course对象
        System.out.println("取得课程:" + course.name);
        System.out.println("备选课程中是否包含课程:" + course.name + ", " + 
                coursesToSelect.contains(course));
        // 提示输入课程名称
        System.out.println("请输入课程名称:");
        String name = console.next();
        // 创建一个新的课程对象,ID和名称,与course对象完全一样
        Course course2 = new Course();
        course2.name = name;
        System.out.println("新创建课程:" + course2.name);
        System.out.println("备选课程中是否包含课程:" + course2.name + ", " +
                coursesToSelect.contains(course2));
        // 通过indexOf方法来取得某元素的索引位置
        if (coursesToSelect.contains(course2))
            System.out.println("课程:" + course2.name + "的索引位置为:" + 
                    coursesToSelect.indexOf(course2));
    }

public static void main(String[] args) {
        SetTest st = new SetTest();
        st.testAdd();
        st.testListContains();
}
Course.java
/*
     * 重写某个类的equals方法的模板
     * 
     */
    @Override
    public boolean equals(Object obj) {  //equals返回类型boolean
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (!(obj instanceof Course))
            return false;
        Course other = (Course) obj; //
        if (name == null) {
            if (other.name == null)
                return true;
            else 
                return false;
        }else{
            if (name.equals(other.name))
                return true;
            else
                return false;
        }
    }

2、学生选课-判断Set中课程是否存在

java中所有类都继承于object类,它定义了一个equals(Object obj)方法,这个方法需要一个参数,还定义了一个HashCode()方法,它返回的是哈希码

package student;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;

public class SetTest {
    
    public List<Course> coursesToSelect;
    private Scanner console;
    public Student student; 
    public SetTest() {
        coursesToSelect = new ArrayList<Course>();
        console = new Scanner(System.in);
    }
    
    /**
     * 用于往coursesToSelect中添加备选课程
     */
    public void testAdd() {
        //创建一个课程对象,并通过调用add方法,添加到备选课程List中
        Course cr1 = new Course("1" , "数据结构");
        coursesToSelect.add(cr1);
        Course temp = (Course) coursesToSelect.get(0);
        
        Course cr2 = new Course("2", "C语言");
        coursesToSelect.add(0, cr2);
        Course temp2 = (Course) coursesToSelect.get(0);
        
        Course[] course = {new Course("3", "离散数学"), new Course("4", "汇编语言")};
        coursesToSelect.addAll(Arrays.asList(course));
        Course temp3 = (Course) coursesToSelect.get(2);
        Course temp4 = (Course) coursesToSelect.get(3);
        
        Course[] course2 = {new Course("5", "高等数学"), new Course("6", "大学英语")};
        coursesToSelect.addAll(2, Arrays.asList(course2));
        Course temp5 = (Course) coursesToSelect.get(2);
        Course temp6 = (Course) coursesToSelect.get(3);
    
    }
/**
     * 通过for each方法访问集合元素
     * @param args
     */
public void testForEach() {
        System.out.println("有如下课程待选(通过for each访问):");
        for (Object obj : coursesToSelect) {
            Course cr = (Course) obj;
            System.out.println("课程:" + cr.id + ":" + cr.name);
        }
    }
// 创建学生对象并选课
        public void createStudentAndSelectCours() {
            //创建一个学生对象
            student = new Student("1", "小明");
            System.out.println("欢迎学生:" + student.name + "选课!");
            //创建一个Scanner对象,用来接收从键盘输入的课程ID
            Scanner console = new Scanner(System.in);
            
            for (int i = 0; i < 3; i++) {
                System.out.println("请输入课程ID");
                String courseId = console.next();
                for (Course cr : coursesToSelect) {
                    if(cr.id.equals(courseId)) {
                        student.courses.add(cr);
                        /**
                         * Set中,添加某个对象,无论添加多少次,
                         * 最终只会保留一个该对象(的引用),
                         * 并且,保留的是第一次添加的那一个
                         */
//                      student.courses.add(null);
//                      student.courses.add(cr);
                    }
                }
            }
    }
        /**
         * 测试Set的contains方法
         */
        public void testSetContains() {
            // 提示输入课程名称
            System.out.println("请输入学生已选的课程名称:");
            String name = console.next();
            // 创建一个新的课程对象,ID和名称,与course对象完全一样
            Course course2 = new Course();
            course2.name = name;
            System.out.println("新创建课程:" + course2.name);
            System.out.println("备选课程中是否包含课程:" + course2.name + ", " +
                    student.courses.contains(course2));
        }
    
    public static void main(String[] args) {
        SetTest st = new SetTest();
        st.testAdd();
        st.testForEach();
        st.createStudentAndSelectCours();
        st.testSetContains();
}
package student;

/*
 * 课程类
 */
public class Course {
    public String id;
    public String name;
    public Course(String id, String name) {
        this.id = id ;
        this.name = name;
    }
    
    public Course(){
        //否则ChildCourse会报错
    }
    
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((name == null) ? 0 : name.hashCode());
        return result;
    }
}

3、学生选课-获取List中课程的位置

如果课程序列包含某门课程,如何判断该课程的索引位置

// 通过indexOf方法来取得某元素的索引位置
            if (coursesToSelect.contains(course2))
                System.out.println("课程:" + course2.name + "的索引位置为:" + 
                        coursesToSelect.indexOf(course2));

4、学生选课-判断Map中是否包含指定的key和value

在学生映射列表中,如何判断是否包含某个学生的ID
又该如何判断是否包含某个学生对象

public void testPut() {
        // 创建一个Scanner对象,用来获取输入的学生ID和姓名
        Scanner console = new Scanner(System.in);
        int i = 0;
        while (i < 3) {
            System.out.println("请输入学生ID:");
            String ID = console.next();
            // 判断该ID是否被占用
            Student st = students.get(ID);
            if (st == null) {
                // 提示输入学生姓名
                System.out.println("请输入学生姓名:");
                String name = console.next();
                // 创建新的学生对象
                Student newStudent = new Student(ID, name);
                // 通过调用students的put方法,添加ID-学生映射
                students.put(ID, newStudent);
                System.out.println("成功添加学生:" + students.get(ID).name);
                i++;
            } else {
                System.out.println("该学生ID已被占用!");
                continue;
            }
        }
    }
    
    /**
     * 测试Map的keySet方法
     */
    public void testKeySet() {
        // 通过keySet方法,返回Map中的所有“键”的Set集合
        Set<String> keySet = students.keySet();
        // 取得students的容量
        System.out.println("总共有:" + students.size() + "个学生!");
        // 遍历keySet,取得每一个键,再调用get方法取得每个键对应的value
        for (String stuId : keySet) {
            Student st = students.get(stuId);
            if (st != null)
                System.out.println("学生:" + st.name);
        }
    }

/**
     * 测试Map中,是否包含某个Key值或者某个Value值
     */
    public void testContainsKeyOrValue() {
        // 提示输入学生id
        System.out.println("请输入要查询的学生ID:");
        Scanner console = new Scanner(System.in);
        String id = console.next();
        // 在Map中,用containsKey()方法,来判断是否包含某个Key值
        System.out.println("您输入的学生ID为:" + id + ",在学生映射表中是否存在:"
                + students.containsKey(id));
        if (students.containsKey(id))
            System.out.println("对应的学生为:" + students.get(id).name);
        // 提示输入学生姓名
        System.out.println("请输入要查询的学生姓名:");
        String name = console.next();
        // 用containsValue()方法,来判断是否包含某个Value值
        //这里需要重写student类的equals方法,否则映射表中不存在。。。
        if (students.containsValue(new Student(null,name)))
            System.out.println("在学生映射表中,确实包含学生:" + name);
        else
            System.out.println("在学生映射表中不存在该学生!");
    }
    


public static void main(String[] args) {
        MapTest mt = new MapTest();
        mt.testPut();
        mt.testKeySet();
        mt.testContainsKeyOrValue();
    }

5、应用Collections.sort()实现List排序

Arrays类--java.util.Arrays包含操作数组的各种静态方法
Collections工具类--java.util.Collections用来操作集合对象的工具类,也是Java集合框架的成员
Collections中定义了sort()排序方法

package student;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Random;

/*
 * 将要完成:
 * 1、通过Collections.sort()方法,对Interger泛型的List进行排序
 * 2、对String泛型的List进行排序
 * 3、对其他类型泛型的List进行排序,以Student为例
 */
public class CollectionsTest {

    /*
     *  1、通过Collections.sort()方法,对Interger泛型的List进行排序
     *  创建一个Iteger类型的List,插入是个100以内的不重复的随机整数
     *  调用Collections.sort()方法排序
     *  练习:
     *  创建List<String>后,往其中添加10条随机字符串,每条字符串长度为10以内的随机整数
     *  每条字符串的每个字符都为随机生成的字符,字符可以重复,每条随机生成的字符串不可重复
     */
    public void testSort1(){
        List<Integer> integerList=new ArrayList<Integer>();
        //插入是个100以内的不重复的随机整数
        Random random=new Random();
        Integer k;
        for(int i=0;i<10;i++){
            do{
                k=random.nextInt(100);  
            }while(integerList.contains(k));//如果已经包含随机数k则需要继续生成一个随机数
            integerList.add(k);
            System.out.println("成功添加整数:"+k);
        }
        System.out.println("----------排序前----------");
        //迭代integer中的每个元素
        for(Integer integer:integerList){
            System.out.println("元素:"+integer);
        }
        Collections.sort(integerList);
        System.out.println("----------排序后----------");
        for(Integer integer:integerList){
            System.out.println("元素:"+integer);
        }
    }
    
    /*
     * 2、对String泛型的List进行排序
     * 创建String泛型的List,添加三个乱序的String元素
     * 调用sort方法,再次输出排序后的顺序
     */
    public void testSort2(){
        List<String> stringList=new ArrayList<String>();
        stringList.add("microsoft");
        stringList.add("google");
        stringList.add("lenovo");
        System.out.println("----------排序前----------");
        for(String string:stringList){
            System.out.println("元素:"+string);
        }
        Collections.sort(stringList);
        System.out.println("----------排序后----------");
        for(String string:stringList){
            System.out.println("元素:"+string);
        }
    }
   
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        CollectionsTest ct=new CollectionsTest();
        ct.testSort1();
        ct.testSort2();
    }

}
 public void testSort3() { 
        List<String> stringList = new ArrayList<String>(); 
        for (int i = 0; i < 10; i++) { 
            StringBuilder tempString = new StringBuilder(); 
            Random random = new Random(); 
            Character[] ku = { '0', 'A', 'a' };
            do { 
                int k = (int) (Math.random() * 10); 
            // System.out.println(k); 
            for (int j = 0; j <= k; j++) { 
            int t = random.nextInt(3); 
            if (t == 0) { 
                tempString.append((char) (ku[t].charValue() + random .nextInt(10))); 
                } else {
                    tempString.append((char) (ku[t].charValue() + random .nextInt(26))); 
                    } 
            } 
            } while (stringList.contains(tempString.toString()));
            stringList.add(tempString.toString());
            } 
        System.out.println("-------------排序前-------------"); 
        for (String st : stringList) { 
            System.out.println("元素:" + st); 
            } 
        Collections.sort(stringList); 
        System.out.println("-------------排序后-------------");
        for (String st : stringList) { 
            System.out.println("元素:" + st); 
            } 
        }
        

public void testSort4(){ 
         List<String> stringList = new ArrayList<String>(); 
         for (int i = 0; i < 10; i++) { 
             StringBuilder tempString = new StringBuilder(); 
             Random random = new Random(); 
             do { 
                 int k = random.nextInt(10); 
                 for (int j = 0; j <= k; j++){ 
                     int t = random.nextInt(3); 
                     if (t == 0) { 
                         tempString.append((char)('0' + random.nextInt(10))); 
                         } else if (t == 1) { 
                             tempString.append((char)('A' + random.nextInt(26))); 
                         } else { 
                             tempString.append((char)('a' + random.nextInt(26))); 
                         } 
                     } 
                 } while(stringList.contains(tempString.toString())); 
             stringList.add(tempString.toString()); 
             } 
         System.out.println("--------排序前--------"); 
         for (String st : stringList) { 
             System.out.println("将要添加字符串:'" + st + "'"); 
             } 
         Collections.sort(stringList); 
         System.out.println("--------排序后--------"); 
         for (String st : stringList) { 
             System.out.println("元素:" + st); 
             } 
         }

6、学生选课-尝试对学生序列排序

7、Cpmparable&Comparator简介

8、学生选课-实现学生序列排序

java 集合框架--collection接口--collections工具类--Map接口--Comparator接口--Comparable接口

// 3、对其他类型泛型的List进行排序,以Student为例
     /*
      * comparable接口,给对象定义了默认的排序规则,comparator接口--临时比较规则,
      * comparable接口--可比较的
      * --实现该接口表示:这个类的实例可以比较大小,可以进行自然排序
      * --定义了默认的比较规则
      * --其实现类需实现compareTo()方法
      * --compareTo()方法返回正数表示的,负数表示小,0表示相等
      * comparator接口--比较工具
      * --用于定义临时比较规则,而不是默认比较规则
      * --其实现类需要实现compare()方法
      * --comparator和comparable都是Java集合框架的成员
      */
    public void testSort5(){
        List<Student> studentList=new ArrayList<Student>();
        Random random=new Random();
        studentList.add(new Student(random.nextInt(1000)+"","Mike"));
        studentList.add(new Student(random.nextInt(1000)+"","Angela"));
        studentList.add(new Student(random.nextInt(1000)+"","Lucy"));
        studentList.add(new Student(10000+"","Lake"));
        System.out.println("--------排序前--------");
         for (Student student: studentList) { 
             System.out.println("学生:" +student.id+":"+ student.name ); 
             } 
         //需要对Student类进行改造,使它实现comparable接口
         Collections.sort(studentList);
         System.out.println("--------排序后--------");
         for (Student student: studentList) { 
             System.out.println("学生:" +student.id+":"+ student.name ); 
             }       
         Collections.sort(studentList,new StudentComparator());
         System.out.println("--------按照姓名排序后--------");
         for (Student student: studentList) { 
             System.out.println("学生:" +student.id+":"+ student.name ); 
             } 
    }

student.java
public class Student implements Comparable<Student> {

...........
@Override
    public int compareTo(Student o) {
        // TODO Auto-generated method stub
        return this.id.compareTo(o.id);
    }
}
上一篇 下一篇

猜你喜欢

热点阅读