二.List中存放若干学生对象(学生有学号,姓名,性别等属性),去除List中重复的元素,并按学号降序输出。(请百度并利用LinkedHashSet集合,既不会重复,同时有可预测的顺序即输入顺序)

学生类:由于是判断对象是否重复所以我们在学生类中必须重写equals方法和hashcode方法
最后要排序还得实现Comparable接口,重写compareTo方法。

import java.util.Objects;

public class Student implements Comparable<Student>{
    private String name;
    private int id;
    private char sex;
    public Student(String name, int id, char sex) {
        this.name = name;
        this.id = id;
        this.sex = sex;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public char getSex() {
        return sex;
    }

    public void setSex(char sex) {
        this.sex = sex;
    }

    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\'' +
                ", id=" + id +
                ", sex=" + sex +
                '}';
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Student student = (Student) o;
        return id == student.id &&
                sex == student.sex &&
                name.equals(student.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, id, sex);
    }


    @Override
    public int compareTo(Student o) {
        Student a=o;
        if(this.id>a.id) return -1;
        if(this.id<a.id) return 1;
        return 0;
    }
}

测试:LinkedHashSet集合要转变为TreeSet才能实现Iterator接口的遍历所以还要转变为TreeSet。

import java.util.Iterator;
import java.util.LinkedHashSet;
import java.util.TreeSet;

/**
 * 二.List中存放若干学生对象(学生有学号,姓名,性别等属性),去除List中重复的元素,并按学号降序输出。
 * (请百度并利用LinkedHashSet集合,既不会重复,同时有可预测的顺序即输入顺序)
 */
public class Test7 {
    public static void main(String[] args) {
        LinkedHashSet linkedHashSet=new LinkedHashSet();
        linkedHashSet.add(new Student("zhangsan",101,'M'));
        linkedHashSet.add(new Student("zhangsan",101,'M'));
        linkedHashSet.add(new Student("lisi",102,'F'));
        linkedHashSet.add(new Student("wangmazi",108,'M'));
        linkedHashSet.add(new Student("wangwu",104,'M'));
        linkedHashSet.add(new Student("zhaoliu",106,'M'));
        System.out.println(linkedHashSet.size());
        TreeSet treeSet=new TreeSet(linkedHashSet);
        Iterator iter=treeSet.iterator();
        while (iter.hasNext()){
            System.out.println(iter.next());
        }

    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet、TreeSet) 3)了解List接口及主要实现类(ArrayListLinkedList、Vector) 4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable) 、实验内容及步骤 1、编写程序练习将以下5个Person类的对象放在一个HashSet姓名:张三 身份证号:178880001 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880003 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880004 注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。 其计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id (注:name:Person对象姓名,id:Person对象的身份证号) 主方法作如下测试: 1)创建一个可放置Person类对象HashSet; 2)依次添加上述5个对象HashSet; 3)把集合元素打印出来(使用迭代器Iterator) 2、编写程序练习List集合的基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序集合添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印集合的每个元素的位置与内容; 4)打印集合的大小,然后删除集合的第3个元素,并显示删除元素的内容,然后再打印目前集合第3个元素的内容,并再次打印集合的大小。 3、编写程序练习Map集合的基本使用: 1)创建一个只能容纳String对象的person的HashMap集合; 2)往集合添加5个"键-值"对象: "id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java" 3)对集合进行遍历,分别打印集合的每个元素的键与值; 4)打印集合的大小,然后删除集合的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。 四、思考题 1、集合List、Set、Map有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?
以下是一个简单的学生列表页面list.jsp的示例代码: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>学生列表</title> </head> <body> <h1>学生列表</h1> <table border="1"> <thead> <tr> <th>学号</th> <th>姓名</th> <th>性别</th> <th>电话</th> <th>操作</th> </tr> </thead> <tbody> <% // 假设学生信息存储在一个List<Student> List<Student> studentList = (List<Student>) request.getAttribute("studentList"); if (studentList != null) { for (Student student : studentList) { %> <tr> <td><%= student.getStudentNo() %></td> <td><%= student.getName() %></td> <td><%= student.getGender() %></td> <td><%= student.getPhone() %></td> <td> <a href="edit.jsp?studentNo=<%= student.getStudentNo() %>">编辑</a> <a href="delete.jsp?studentNo=<%= student.getStudentNo() %>" onClick="return confirm('确定要删除该学生吗?')">删除</a> </td> </tr> <% } } else { %> <tr> <td colspan="5">暂无学生信息</td> </tr> <% } %> </tbody> </table> <a href="add.jsp">添加学生</a> </body> </html> ``` 该页面使用了JSP技术,通过Java代码动态生成HTML内容。其,<% %>用于插入Java代码,<%= %>用于输出Java表达式的值。具体来说,该页面做了以下事情: 1. 显示页面标题和表头; 2. 遍历学生列表,输出每个学生的信息和编辑、删除链接; 3. 如果学生列表为空,则显示“暂无学生信息”; 4. 显示“添加学生”链接,用于跳转到添加学生页面。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值