2020.10.16每日复习

811.子域名访问计数

在这里插入图片描述
在这里插入图片描述
分析

  • 对数组中的每一个字符串进行遍历,如果遍历到空格,说明空格前的字符拼接起来就是访问次数,令为times,而此时空格后的第一个字符到字符串最后,拼接起来就是域名,并且是最全的域名,连同访问次数存进map集合中。
  • 继续遍历,当遍历到 ’ . ‘,说明’ . '往后的字符表示一个子域名,连同这个字符的访问次数一起存进map集合中,并判断是否出现过,若map中已有这个子域名,则累加即可。
  • 最后将域名及其访问次数一起输出。
class Solution {
    public List<String> subdomainVisits(String[] cpdomains) {
        Map<String, Integer> map = new HashMap<>();
        List<String> list = new ArrayList<>();
        int times = 0;
        for(String domain : cpdomains) {
            char[] c : domain.toCharArray();
            for(int i = 0; i < c.length; i++) {
                if(c[i] == ' ') {
                    times = Integer.valueOf(new String(c, 0, i));
                    String s = new String(c, i + 1, c - i - 1);
                    map.put(s, map.getOrDefault(s, 0) + times);
                }
                if(c[i] == '.') {
                    String s = new String(c, i + 1, c - i - 1);
                    map.put(s, map.getOrDefault(s, 0) + times);
                }
            }
        }
        for(Map.Entery<String, Integer> entry = map.entrySet()) {
            StringBuilder sb = new StringBuilder();
            list.add(sb.append(entry.getValue()).append(".").append(entry.getKey()).toString());
            //list.add(entry.getValue() + " " + entry.getKey());方法二
        }
        return list;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值