import java.util.TreeSet; class Stu implements Comparable<Stu>{ private String id; private String name; public Stu(String id, String name) { super(); this.id = id; this.name = name; } public String toString() { return id+" "+name; } public int compareTo(Object o) { // TODO Auto-generated method stub return 0; } } public class G1 { public static void main(String[] args) { TreeSet ts= new TreeSet(); Stu s1=new Stu("1","对"); Stu s2=new Stu("2","啊"); Stu s3=new Stu("3","他反"); Stu s4=new Stu("4","给方"); ts.add(s1); ts.add(s3); ts.add(s2); ts.add(s4); System.out.println(ts); } }
时间: 2023-12-06 15:41:25 浏览: 28
这段代码实现了一个简单的学生类Stu,其中包括学生的姓名和ID。这个类实现了Comparable接口,用于比较两个学生对象的大小。在main函数中,创建了一个TreeSet对象ts,并向其中添加了4个学生对象s1、s2、s3、s4。因为TreeSet会自动按照元素的大小进行排序,所以最后输出结果会按照字典序排列。输出结果为:
1 对
2 啊
3 他反
4 给方
相关问题
package shiyan; import java.util.Comparator; import java.util.TreeSet; class MyComparator implements Comparator<String> { public int compare(String s1, String s2) { return s1.length() - s2.length(); } } public class ComparatorDemo { public static void main(String[] args) { TreeSet<String> ts = new TreeSet<>(new MyComparator()); ts.add("Jack"); ts.add("Helena"); ts.add("Eve"); System.out.println(ts); } }分析此代码
这段代码实现了一个自定义比较器 `MyComparator`,用来比较 `String` 类型的对象。`MyComparator` 类实现了 `Comparator<String>` 接口,重写了 `compare` 方法,比较两个字符串的长度。
在 `main` 方法中,创建了一个 `TreeSet<String>` 对象 `ts`,并传入 `MyComparator` 对象作为参数,这样 `ts` 中的元素会按照字符串长度从小到大排序。然后向 `ts` 中添加了三个字符串 "Jack","Helena","Eve",最后输出 `ts`,结果为 ["Eve", "Jack", "Helena"],符合预期。
package shiyan4_3; import java.util.TreeSet; public class Student implements TreeSet<Student> { String name; int score; Student(String name,int score) { this.name=name; this.score=score; } /** *补充代码[2],重写compareTo()方法 **/ public int getScore() { return score; } public String getName() { return name; } }
这段代码有问题,因为Java中的类不能直接实现 TreeSet 接口,而应该实现 Comparable 接口并重写 compareTo 方法。应该修改代码如下:
```java
package shiyan4_3;
import java.util.TreeSet;
public class Student implements Comparable<Student> {
String name;
int score;
Student(String name,int score) {
this.name=name;
this.score=score;
}
/**
* 重写 compareTo() 方法
**/
@Override
public int compareTo(Student other) {
return Integer.compare(this.score, other.score);
}
public int getScore() {
return score;
}
public String getName() {
return name;
}
}
```
在这个例子中,我们假设学生对象之间的比较是基于分数的。因此,compareTo 方法应该比较两个学生对象的分数,并返回一个 int 值,表示它们之间的大小关系。如果当前对象的分数小于 other 对象的分数,则返回负值;如果当前对象的分数等于 other 对象的分数,则返回 0;如果当前对象的分数大于 other 对象的分数,则返回正值。这个 compareTo 方法的实现中,使用了 Java 内置的 Integer.compare 方法,来比较两个 int 值的大小关系。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![java](https://img-home.csdnimg.cn/images/20210720083646.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)