Set练习

本文通过三个示例介绍了Java集合框架中HashSet和TreeSet的使用。首先展示了如何使用HashSet去除重复元素,然后利用TreeSet生成并打印8个不重复的10至20之间的随机数。最后,实现了一个Book类,用于存储书名和价格,并使用TreeSet进行自然排序和自定义比较器排序,实现了按价格和书名排序的功能。
摘要由CSDN通过智能技术生成

Java_Set练习

/*
### 题目1

已知数组信息如下:

{2.2,5.5,6.6,2.2,8.8,1.1,2.2,8.8,5.5,2.2,6.6}

请使用代码找出上面数组中的所有的数据,要求重复的数据只能保留一份;

**要求:**

使用HashSet集合实现;
*/

//使用set不保存重复数据,增强for保存

import java.util.HashSet;
import java.util.Set;

public class HM_Set1 {
    public static void main(String[] args) {
        Set<Double> set = new HashSet<>();
        double [] arr = {2.2,5.5,6.6,2.2,8.8,1.1,2.2,8.8,5.5,2.2,6.6};
        for (double v : arr) {
            set.add(v);
        }
        System.out.println(set);
    }
}

/*
### 题目2

随机生成8个不重复的10至20之间的随机数并保存Set集合中,然后打印出集合中所有的数据;

**要求:**

使用TreeSet集合实现;*/

//Treeset自动排序
import java.util.Random;
import java.util.TreeSet;

public class HM_TreeSet {
    public static void main(String[] args) {
        Random random = new Random();
        TreeSet<Integer> treeSet = new TreeSet<>();

        int p = 0;
        while(treeSet.size() < 8)
        {
            int temp = random.nextInt(10)+10;
            System.out.println("第"+(++p)+"次生成的随机数是:" + temp);
            treeSet.add(temp);
        }

        System.out.println("集合中保存的8个不重复的随机数是:"+treeSet);

    }
}

/*
### 题目3

键盘输入3本书按照价格从低到高排序后输出,如果价格相同则按照书名的自然顺序排序;

**要求:**

1:书以对象形式存在,包含书名和价格(int类型)两个属性;

2:要求即使直接打印书对象的时候,也能看到书的名称和价格,而不是书对象的地址值;

3:分别使用自然排序和比较器排序实现效果;
*/
import java.util.Iterator;
import java.util.Scanner;
import java.util.TreeSet;

class book implements Comparable<book>
{
    String name;
    int price;

    public book() {
    }

    public book(String name, int price) {
        this.name = name;
        this.price = price;
    }

    public String getName() {
        return name;
    }

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

    public int getPrice() {
        return price;
    }

    public void setPrice(int price) {
        this.price = price;
    }

    @Override
    public String toString() {
        return "book{" +
                "name='" + name + '\'' +
                ", price=" + price +
                '}';
    }

    @Override
    public int compareTo(book o) {
        return  this.price - o.price;
    }
}

public class HM_Books{
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        TreeSet<book> treeSet = new TreeSet<>();
        int p = 0;
        while(true)
        {
            System.out.println("请输入第"+(++p)+ "本书的名称:");
            String book_name = scanner.next();
            System.out.println("请输入第"+p+"本书的价格(整数):");
            int book_price = scanner.nextInt();
            treeSet.add(new book(book_name,book_price));
            System.out.println("添加"+book_name+"已经成功,继续添加请输入1,输入其他数字将结束!");
            int key = scanner.nextInt();
            if( key !=1)
            {
                break;
            }

        }
        System.out.println("您一共添加了:"+p+"本书,分别是:");
        Iterator<book> it = treeSet.iterator();
        while(it.hasNext())
        {
            System.out.println(it.next());
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值