字符统计(JAVA)

字符统计

http://www.nowcoder.com/questionTerminal/c1f9561de1e240099bdb904765da9ad0

PriorityQueue + HashMap

定义比较方式两种:override compareTo() / lambda表达式

遍历map两种方法:forEach() + lambda表达式 / Map.Entry<>

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
import java.util.PriorityQueue;


public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while(in.hasNext()) {
            String s = in.nextLine();
            Map<Character, Integer> map = new HashMap<Character, Integer>();
            for(int i = 0; i < s.length(); i++) {
                char cur = s.charAt(i);
               map.put(cur, map.getOrDefault(cur, 0) + 1);
            }
            PriorityQueue<Point> pq = new PriorityQueue<>();
            /*
            PriorityQueue<Point> pq = new PriorityQueue<>((x, y) -> -128*(x.number - y.number) + (int)(x.c - y.c));
            for (Map.Entry<Character, Integer> entry : map.entrySet()) {
                Point p = new Point(entry.getKey(), entry.getValue());
                pq.offer(p);
            }
            */
            map.forEach((k, v) -> pq.offer(new Point(k, v)));
            StringBuilder res = new StringBuilder();
            while (!pq.isEmpty()) {
                res.append(pq.poll().c);
        }
        System.out.println(res.toString());
        }
    }
}
class Point implements Comparable<Point>{
    char c;
    int number;
    Point(char c, int number){
        this.c = c;
        this.number = number;
    }
    @Override
    public int compareTo(Point p2){
        if (p2.number != this.number){
            return p2.number - this.number;
        }else {
            return (int)(this.c - p2.c);
        }
    }
}

全部评论
next() 读不了空格吧
1 回复 分享
发布于 2020-07-28 22:18

相关推荐

点赞 评论 收藏
分享
珩珺:那些经历都太大太空了,实习的情况不了解,大创项目连名字、背景、目的及意义都没体现出来;地摊经济更是看完连卖的什么产品都不知道,项目成果直接写营收多少都更直观真实一点;后面那个校文体部的更是工作内容是组织活动整理流程,成果变成了当志愿者,而且你们学校本科学生会大一入学就直接当部长吗,志愿里面还提到了疫情防控,全面解封是22年12月的事情,可能时间上也有冲突。可能你花了钱人家就用AI给你随便写了点内容改了一下,没什么体现个性化的点
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
09-17 14:26
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务