java 容器和泛型之TreeMap

TreeMap类是SortedMap的唯一实现,基于红黑树数据结构,它根据键的自然顺序或者创建映射的Comparator进行排序

 

/**
 * @author yixiao Han
 * @data:2018 10 29
 * @function: test The java Map coding 
 */
package Treemap;

import java.util.*;

class Student {
    public int id;
    public String name;
    public int math_score;
    public int english_score;
    public int computer_score;

    public Student(int id, String name, int math_score, int english_score, int computer_score) {
        this.id = id;
        this.name = name;
        this.math_score = math_score;
        this.english_score = english_score;
        this.computer_score = computer_score;
    }
}

public class MapTest {

    public static void main(String[] args) {
        TreeMap<Integer, Student> map = new TreeMap<>();// public class TreeMap<K,V> 
        /**
         * param <K> the type of keys maintained by this map ‘map的键值
         * @param <V> the type of mapped values’映射的类型     
         * 这句的大致意思为一个整型的数字与一个STudent类型相对应
         * 后面的new<> TreeMap则是泛型的声明方法
         * Generics<String> gen=new Generics<>()
         */
        int total = 0;
        int[] grade = new int[5];
        Student[] s = new Student[5];
        s[0] = new Student(01, "季安", 85, 75, 95);
        s[1] = new Student(02, "老司机", 100, 92, 60);
        s[2] = new Student(03, "yixiao", 92, 50, 100);
        s[3] = new Student(04, "李彦龙", 80, 50, 10);
        s[4] = new Student(05, "宫新港", 70, 80, 82);
        
        for (int i = 0; i < 5; i++) {
            map.put(i + 1, s[i]);
            /*
             * map.put
                 *      public V put(K key, V value) {
                        Entry<K,V> t = root;
                        if (t == null) {
                            compare(key, key); // type (and possibly null) check
                
                            root = new Entry<>(key, value, null);
                            size = 1;
                            modCount++;
                            return null;
                        }
                  往map的表中填入数据 对应的K为键值,S[i]为学生
             */
        }
        int[] arr = new int[5];
        int i = 0;
        int j = Integer.parseInt(args[0]);//获得配置的主函数参数 j=01
        System.out.println("student number   name   computer_score   english_score   math_score   ");
        if (map.containsKey(j)) {
            /**
             * map containsKey(Object key) 
             * 如果此映射包含指定键的映射关系,则返回 true。
             */
            System.out.println("what information you are looking for:");
            Student student = map.get(j);
            System.out.print(student.id + "    ");
            System.out.print(student.name + "   ");
            System.out.print(student.computer_score + "   ");
            System.out.print(student.english_score + "  ");
            System.out.print(student.math_score + "   ");
            total = student.computer_score + student.english_score + student.math_score;// total score
            System.out.print(total);
        }
        else{
            System.out.println("this student is not in our school,please kill the program");
        }
        System.out.println();
        TreeMap<Integer, Student> tp = new TreeMap();
        /**
         * 声明一个新的TreeMap tp
         * 用来保存新的键值和对应的映射类型
         * 重新排序过的内容
         * 基于红黑树(Red-Black tree)的 NavigableMap 实现。该映射根据其键的自然顺序进行排序,
         * 或者根据创建映射时提供的 Comparator 进行排序,具体取决于使用的构造方法。 
         * 即数字从 1 到 9 的排序方法,字母从 a 到 z 的排序方法,短者优先。数组的索引与单元值保持关联。.
         */
        Iterator<Map.Entry<Integer, Student>> it = map.entrySet().iterator();
        /*
         * @Iterator:迭代器,collection接口的iterator和toArry都可以用来遍历容器中的所有元素
         * 前者返回一个Iterator的对象,后者返回一个带有所有元素的数组
         * hasNext函数 判断是否遍历完容器中的所有对象
         * @map.Entry public static interface Map.Entry<K,V>
         * entrySet().iterator()
         * 该种方式看起来冗余却有其优点所在。首先,在老版本java中这是惟一遍历map的方式。
         * 另一个好处是,你可以在遍历时调用iterator.remove()来删除entries,另两个方法则不能
         * 。根据javadoc的说明,如果在for-each遍历中尝试使用此方法,结果是不可预测的。
         */
        System.out.println("before the sort");
        while (it.hasNext()) {
            /**
             * hasNext()函数返回boolean形变量
             */
            Map.Entry entry = it.next();
            /**
             * 容器的入口:用来存储迭代出的元素
             * 
             */
            arr[i] = (Integer) entry.getKey();// 
            /**
             * 返回与此项对应的键,这里为参数为啊s[i]的键值
             */
            s[i] = (Student) entry.getValue();
            /**
             * 返回与此项对应的值。
             */
            System.out.println(s[i].id + "    ");
            System.out.println(s[i].name + "    ");
            System.out.println(s[i].computer_score + "    ");
            System.out.println(s[i].english_score + "    ");
            System.out.println(s[i].math_score + "    ");
            total = s[i].computer_score + s[i].english_score + s[i].math_score;
            System.out.println(total);
            System.out.println();
            grade[i] = total;
            tp.put(grade[i], s[i]);
            /**
             * put(K key, V value) 
             * 将指定值与此映射中的指定键进行关联。
             * 新的map是由总成绩为键值构成的Map
             * 所以新的map tp是由分数自然排序 的
             */
            i++;
            System.out.print(i+"个\n");
            //System.out.print(arr[i]);不可以这样使用
        }
        i = 0;
        System.out.println("after sort");
        Iterator<Map.Entry<Integer, Student>> iter = tp.entrySet().iterator();
        /**
         * 返回Iterator迭代器,用来遍历map中的所有元素
         */
        while (iter.hasNext()) {
            Map.Entry entry1 = iter.next();
            arr[i] = (Integer) entry1.getKey();// 
            s[i] = (Student) entry1.getValue();
            System.out.println(s[i].id + "    ");
            System.out.println(s[i].name + "    ");
            System.out.println(s[i].computer_score + "    ");
            System.out.println(s[i].english_score + "    ");
            System.out.println(s[i].math_score + "    ");
            total = s[i].computer_score + s[i].english_score + s[i].math_score;
            System.out.println(total);
            System.out.println();
        }
    }

}
 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java程序设计》课程实验指导书程序代码(答案)(实验四:java继承与多态),个人原创,仅供参考与交流。 希望多多交流,共同进步! 实验四 java继承与多态 一、实验目的: 掌握继承、多态的概念与实现方法; 掌握包和接口的定义和使用方法; 了解JAVA语言实现多继承的途径; 二、实验内容: 1.分别编写两个类Point2D,Point3D来表示二维空间和三维空间的点,使之满足下列要求: (1) Point2D有两个整型成员变量x, y (分别为二维空间的X,Y方向坐标),Point2D的构造方法要实现对其成员变量x, y的初始化。 (2)Point2D有一个void型成员方法offset(int a, int b),它可以实现Point2D的平移。 (3)Point3D是Point2D的直接子类,它有有三个整型成员变量x,y,z (分别为三维空间的X,Y,Z方向坐标),Point3D有两个构造方法:Point3D(int x,int y,int z)和Point3D(Point2D p,int z),两者均可实现对Point3D的成员变量x, y,z的初始化。 (4)Point3D有一个void型成员方法offset(int a, int b,int c),该方法可以实现Point3D的平移。 (5)在Point3D中的主函数main()中实例化两个Point2D的对象p2d1,p2d2,打印出它们之间的距离,再实例化两个Point2D的对象p3d1,p3d2,打印出他们之间的距离。 2.定义抽象类Shape,抽象方法为showArea(),求出面积并显示,定义矩形类Rectangle,正方形类Square,圆类 Circle,根据各自的属性,用showArea方法求出各自的面积,在main方法中构造3个对象,调用showArea方法。 定义接口DiagArea,其中包含方法double getDiagonal()求对角线长, double getArea()求面积,定义一个矩形类,实现此接口,并自行扩充成员变量和方法,定义一个正方形类继承矩形类(如矩形有长w和宽h,正方形有边x,并有相应的构造函数,有一个方法中一次直接显示边长、面积和对角线长),在另一类中的主方法里使用测试该类。 三、实验要求: 1. 能实现类的继承关系; 2. 用多种方法创建各个类的对象; 3. 程序应包括各个被调用方法的执行结果的显示。 4. 写出实验报告。要求记录编译和执行Java程序当中的系统错误信息提示,并给出解决办法。(附运行界面、源代码)。 四、实验步骤: 1.(第1题)定义Point2D,及定义它的属性和方法; 定义子类Point3D,及定义它的属性和方法;在Point3D中的主函数main()中实例化两个Point2D的对象,并通过这两个对象调用它们的属性和方法,输出方法执行结果。 2.(第2题)定义抽象类Shape,抽象方法为showArea(),再定义矩形类Rectangle,正方形类Square,圆类 Circle,和各自的属性。定义主类、主方法,在main方法中构造3个对象,调用showArea方法;定义接口DiagArea,其中包含方法double getDiagonal(),在主main方法中输出方法执行结果。 五、自做作实验 1.定义一个描述人的基本类,该类包括人的性别和出生日期两个数据成员,以及设置和获取这些属性值的方法成员;再定义一个大学生类,使大学生类具有人的所有属性外,还具有姓名、学号,大学入学成绩,籍贯属性以及设置和获取这些属性值的方法成员;编写完整的程序,完成一个具有班级学生信息管理功能的程序。 2创建一个接口Shape,其中有抽象方法area,类Circle 、Rectangle实现area方法计算其面积并返回。又有Star实现Shape的area方法,其返回值是0,Star类另有一返回值boolean型方法isStar;在main方法里创建一个Vector,根据随机数的不同向其中加入Shape的不同子类对象(如是1,生成Circle对象;如是2,生成Rectangle对象;如是3,生成Star对象)。然后将Vector中元素依次取出,判断其是否为Star类。如是返回其是个Star。否则返回其面积。 3..学校中有老师和学生两类人,而在职研究生既是老师又是学生,对学生的管理和对教师的管理在他们身上都有体现。 1)设计两个信息管理接口StudentManageInterface和TeacherManageInterface。其中,StudentInterface接口包括setFee()方法和getFee()方法,分别用于设置和获取学生的学费;TeacherInterface接口包括setPay()方法和getPay()方法,分别用于设置和获取教师的工资 2) 定义一个研究生类Graduate,实现StudentInterface接口和TeacherInterface接口,它定义的成员变量有name(姓名)、sex(性别)、age(年龄)、fee(每学期学费)、pay(月工资)。 3) 创建一个姓名为“zhangsan”的研究生,统计他的年收入和学费,如果收入减去学费不足2000元,则输出“provide a loan”(需要贷款)信息。 提示: 1)定义两个接口,分别在其中申明两个方法。 2)定义主类Graduate,实现这两个接口。 3)定义主类的成员变量,和构造方法。 4)给出四个接口方法的实现。 5)给出一个计算是否需要贷款的方法,在里面统计年收入和学费,并输出是否需要贷款的信息。 6)写main方法。在其中创建一个姓名为“zhangsan”的研究生,调用计算是否需要贷款的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值