题解 | #合并表记录#

合并表记录

https://www.nowcoder.com/practice/de044e89123f4a7482bd2b214a685201

import java.util.LinkedList;
import java.util.List;
import java.util.Scanner;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        in.useDelimiter("\n");
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNext()) { // 注意 while 处理多个 case
            int count = in.nextInt();
            List<String> list = new LinkedList<>();
            outer:
            for(int i = 1; i <= count; i ++) {
                String key_value = in.next();
                String[] split = key_value.split(" ");
                int key = Integer.valueOf(split[0]);
                int value = Integer.valueOf(split[1]);
                for(int j = 0; j < list.size(); j ++) {
                    String s = list.get(j);
                    String[] split1 = s.split(" ");
                    int currKey = Integer.valueOf(split1[0]);
                    int currVal = Integer.valueOf(split1[1]);

                    if(currKey == key) {
                        list.set(j, key + " " + (currVal + value) );
                        continue outer;
                    }
                }
                list.add(key + " " + value);
            }
            list.sort(((o1, o2) -> Integer.valueOf(o1.split(" ")[0]) - Integer.parseInt(o2.split(" ")[0])));
            for(String s : list) {
                System.out.println(s);
            }
        }
    }
}

全部评论
用map会有效率问题,这个依然不是最优解,但是先通过再说,逻辑性强一点
点赞 回复 分享
发布于 2023-07-21 04:38 江苏

相关推荐

shtdbb_:还不错,没有让你做了笔试再挂你
点赞 评论 收藏
分享
牛客868257804号:九个中铁八个中建
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-24 20:55
阿里国际 Java工程师 2.7k*16.0
程序员猪皮:没有超过3k的,不太好选。春招再看看
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务