用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - java代码库

输入一个字符串,确定每个字符串的个数,然后按照个数的多少升序输出。

2017-09-09 作者:低调的小飞举报

[java]代码库

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map.Entry;
import java.util.Scanner;

public class StringChat {

	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		String s = sc.nextLine();
		sc.close();
		HashMap<Character, Integer> hashmap = new HashMap<Character, Integer>();
		for (int i = 0; i < s.length(); i++) {
			if (hashmap.containsKey(s.charAt(i))) {
				hashmap.put(s.charAt(i), hashmap.get(s.charAt(i)) + 1);
			} else {
				hashmap.put(s.charAt(i), 1);
			}
		}
		Iterator<?> iter = hashmap.entrySet().iterator();
		while (iter.hasNext()) {
			@SuppressWarnings("unchecked")
			Entry<Character, Integer> next = (Entry<Character, Integer>)iter.next();
			Entry<Character, Integer> entry = next;
			Character c = (Character) entry.getKey();
			Integer n = (Integer) entry.getValue();
			System.out.println(c + "  :  " + n);
		}
		List<Entry<Character, Integer>> list = new ArrayList<Entry<Character, Integer>>(hashmap.entrySet());
		Collections.sort(list, new Comparator<Entry<Character, Integer>>() {
			@Override
			public int compare(Entry<Character, Integer> o1, Entry<Character, Integer> o2) {
				return o1.getValue() - o2.getValue();
			}
		});
		StringBuilder strBuilder = new StringBuilder();
		for (int i = 0; i < list.size(); i++) 
			for (int j = 0; j < list.get(i).getValue(); j++)
				strBuilder.append(list.get(i).getKey());
		System.out.println(strBuilder.toString());
	}
	
}



分享到:
更多

网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。