java随机数去重排序_java中TreeSet存储Random生成的随机数没有去重

写一个Student类, 包含属性id[1-30), grade[1-6], score[0-100], 所有属性都是随机生成

创建一个Set集合, 保存20个对象, 如果两个对象的id是一样的,则不允许添加. 使用迭代器遍历集合,打印输出对象的信息,

并找出分数最高的同学和分数最低的同学, 最后打印输出最高分和最低分同学信息.

本人写的利用TreeSet的代码如下

public class HomeWork6Compare {

public static void main(String[] args) {

TreeSetset = new TreeSet(new Comparator() {

@Override

public int compare(Student1 stu1, Student1 stu2) {

if(stu1.id == stu2.id) {

return 0;

}

int result = stu1.score - stu2.score;

if(result == 0) {

return 1;

}

return result;

}

});

Random r = new Random();

Student1 s = null;

int id=0,grade=0,score=0;

while(set.size()<20) {

id = r.nextInt(29)+1;

grade = r.nextInt(6)+1;

score = r.nextInt(100)+1;

s = new Student1(id, grade, score);

set.add(s);

}

Iteratoriterator = set.iterator();

while(iterator.hasNext()) {

System.out.println(iterator.next());

}

System.out.println("分数最高的同学信息如下:");

System.out.println(set.first());

System.out.println("分数最低的同学信息如下:");

System.out.println(set.last());

}

}

运行截图如下图

4f53056d3b6f7a256c5885430ecb8b52.png

发现运行结果中有多组重复id,经过几次检查也没发现compare方法有什么错误,后面自己取消随机数输入数据,手写了二十几组数据却发现没有重复id出现(这里就不拿出源码和运行截图,有兴趣的自己可以试试),后用HashSet去重,TreeSet排序解决了这个问题,但还是不懂单纯的TreeSet为什么不能做到去重,求大神指点。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java代码如下:import java.util.*;public class RandomNumber{ public static void main(String[] args){ Set<Integer> set = new TreeSet<Integer>(); Random random = new Random(); while(set.size()<14){ int num = random.nextInt(30)+1; set.add(num); } System.out.println(set); } } ### 回答2: 以下是使用 Java 随机生成 14 个 1~30 的不重复随机数的代码: ```java import java.util.ArrayList; import java.util.Random; public class RandomNumberGenerator { public static void main(String[] args) { ArrayList<Integer> randomNumbers = generateRandomNumbers(14, 1, 30); for (Integer number : randomNumbers) { System.out.println(number); } } public static ArrayList<Integer> generateRandomNumbers(int count, int min, int max) { ArrayList<Integer> randomNumbers = new ArrayList<Integer>(); Random random = new Random(); while (randomNumbers.size() < count) { int randomNumber = random.nextInt(max - min + 1) + min; if (!randomNumbers.contains(randomNumber)) { randomNumbers.add(randomNumber); } } return randomNumbers; } } ``` 这段代码使用了 `ArrayList` 来存储生成的不重复随机数。`generateRandomNumbers` 方法接受三个参数:随机数的个数 `count`、最小值 `min` 和最大值 `max`。代码使用 `Random` 类来生成随机数,然后通过循环不断生成新的随机数直到达到指定的个数。每次生成随机数会判断是否已经存在于 `ArrayList` ,若不存在则加入,否则继续生成新的随机数。最终返回生成的不重复随机数的 `ArrayList`。在 `main` 方法,我们调用 `generateRandomNumbers` 方法生成 14 个 1~30 的不重复随机数,并打印到控制台上。 ### 回答3: Java随机生成不重复的14个1~30的随机数代码如下: ```java import java.util.HashSet; import java.util.Random; import java.util.Set; public class RandomGenerator { public static void main(String[] args) { Set<Integer> set = new HashSet<>(); Random random = new Random(); while (set.size() < 14) { int randomNumber = random.nextInt(30) + 1; // 生成1~30之间的随机数 set.add(randomNumber); // 添加到set,保证不重复 } System.out.println("随机生成的14个不重复的随机数为:"); for (int num : set) { System.out.print(num + " "); } } } ``` 以上代码使用了Set集合来存储随机生成的数字,并利用HashSet的特性保证了存入的数字不重复。使用Random生成随机数,并通过`random.nextInt(30) + 1`来限制随机数的范围在1~30之间。通过循环,直到集合大小达到14时停止生成随机数。最后,将集合的数字打印出来,即为14个不重复的随机数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值