HJ8 合并表记录

该程序使用Java解决HJ8问题,通过创建哈希表存储键值对,遇到重复键时将值累加。输入是表格数据,程序读取并处理这些数据,最后按键排序并打印结果。时间复杂度为O(N)。
摘要由CSDN通过智能技术生成

题目

HJ8 合并表记录

题解

用map哈希表存储key、value,存在相同key则把value值相加。

import java.util.*;
import java.util.stream.Collectors;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = Integer.parseInt(in.nextLine());
        List<String> list = new ArrayList<>(n);
        for (int i = 0; i < n; i++) {
            list.add(in.nextLine());
        }

        Map<Integer, Integer> integerMap = merge(list);
        List<Integer> keyList = integerMap.keySet().stream().sorted().collect(
                                    Collectors.toList());
        for (Integer key : keyList) {
            System.out.println(key + " " + integerMap.get(key));
        }
    }

    public static Map<Integer, Integer> merge(List<String> list) {
        Map<Integer, Integer> map = new HashMap<>();
        for (String s : list) {
            String[] split = s.split(" ");
            int index = Integer.parseInt(split[0]);
            int value = Integer.parseInt(split[1]);
            map.put(index, map.getOrDefault(index, 0) + value);
        }

        return map;
    }
}

时间复杂度:O(N)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值