Java、计算数字的出现次数

编写程序,读取1~100之间的整数,然后计算每个数出现的次数。假定输入0表示结束。

注意:如果一个数出现的次数大于一次,则在输出是使用“times”。以升序显示数字。 


package pack2;

import java.util.Map.Entry;
import java.util.Scanner;
import java.util.Set;
import java.util.TreeMap;

public class Count {

	public static void main(String[] args) {
		try(Scanner input = new Scanner(System.in);) {
			count2(input);
		}
	}

	/**计算数字的出现次数(方法一)*/
	public static void count2(Scanner input) {
		TreeMap<Integer, Integer> map = new TreeMap<>();
		int integer;
		
		System.out.print("Enter the integers between 1 and 100: ");
		do {
			integer = input.nextInt();
			if(integer != 0)
				if(!map.containsKey(integer))
					map.put(integer, 1);
				else 
					map.put(integer, map.get(integer) + 1);
		}while(integer != 0);
		
		Set<Entry<Integer, Integer>> set = map.entrySet();
		for (Entry<Integer, Integer> entry : set) {
			System.out.println(entry.getKey()+" occurs "+entry.getValue()+ 
                                 (entry.getValue() == 1 ? " time" : " times"));
		}
	}

	/**计算数字的出现次数(方法二)*/
	public static void count1(Scanner input) {
		int[] array = new int[100];
		int integer;
		
		System.out.print("Enter the integers between 1 and 100: ");
		do {
			integer = input.nextInt();
			if(integer != 0)
				array[integer - 1]++;
		}while(integer != 0);
		
		for (int i = 0; i < array.length; i++) 
			if(array[i] != 0)
				System.out.println((i + 1)+" occurs "+array[i]+(array[i] == 1 ? " time" 
                                     : " times"));
	}
	
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值