Set集合的练习

练习1:键盘录入多个数据,以0结束,要求在控制台输出这多个数据中的最大值

分析:

  键盘输入,创建键盘对象以0结束----while条件,输入0则break跳出循环
  由于不知道元素的个数,长度不固定,必须用集合; 
  不能用数组原因:数组长度固定,由于不知道数据的个数 ;
  TreeSet集合具有自然排序的功能

代码

package 测试2;

import java.util.Iterator;
import java.util.Scanner;
import java.util.TreeSet;


/*
 
 * ***************************** 
 * 思考1:如果要统计最大值的个数,该怎么办? 
 * 分析:此时显然用TreeSet不行,那怎么办?
 * 可以用ArrayList存储元素,然后将集合转化成数组; 利用数组的方法进行排序,找到最大值,对数组遍历统计最大值个数
 * *******************************
 * 思考2:
 * 如果要将字符串(数字)进行排序呢?
 * 已知字符串(数字),以空格隔开-----String的split方法,转换成字符串的数组
 * 然后利用Integer的parseInt方法将数字字符串转换成整型
 */
public class DemoHomeWork {

	public static void main(String[] args) {
		// 创建集合,存储元素
		TreeSet<Integer> set = new TreeSet<Integer>();// 无参:默认自然排序
		// 创建键盘录入对象
		Scanner sc = new Scanner(System.in);
		while (true) {
			System.out.print("请输入数据:");
			int a = sc.nextInt();// 存储变量
			set.add(a);
			if (a == 0) {
				break;
			} 
		}
		// 元素输入完了,以0结束
		//方法1
		System.out.println("元素排序为:" + set);
		Object[] obj=set.toArray();
		System.out.println(obj[obj.length-1]);//多态形式
		//方法2
		/**
		 * 或者:说明:<T> T[] toArray(T[] a)------T=Integer
		 */
		Integer[] arr = set.toArray(new Integer[set.size()]);
		System.out.println("最大值为:" + arr[arr.length - 1]);
		// 或者
		System.out.println("最大值为:" + arr[arr.length - 1].intValue());
        // 方法3
		//创建迭代器对象----迭代器遍历过程中找到最大值(依赖于TreeSet排序)
		Iterator<Integer> it=set.iterator();
		while(it.hasNext()){
			Integer temp=it.next();
			if(it.hasNext()==false){
				System.out.println("最大值为:"+temp);
			}
			
		}
	}
}
未完待续......



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值