首页 > 代码库 > 数据表记录包含表索引和数值,请对表索引相同的记录进行合并,即将相同索引的数值进行求和运算,输出按照key值升序进行输出。
数据表记录包含表索引和数值,请对表索引相同的记录进行合并,即将相同索引的数值进行求和运算,输出按照key值升序进行输出。
题目描述
数据表记录包含表索引和数值,请对表索引相同的记录进行合并,即将相同索引的数值进行求和运算,输出按照key值升序进行输出。
输入描述:
先输入键值对的个数
然后输入成对的index和value值,以空格隔开
输出描述:
输出合并后的键值对(多行)
输入例子:
4 0 1 0 2 1 2 3 4
输出例子:
0 3 1 2 3 4
import java.util.Scanner; import java.util.SortedMap; import java.util.TreeMap; public class Main { public static void main(String[] args) { Scanner str = new Scanner(System.in); SortedMap<Integer,Integer> map = new TreeMap<>(); int n = Integer.parseInt(str.nextLine()); for ( int i = 0 ;i<n;i++){ String[] mid = str.nextLine().split( "\\s+" ); addPare(map,mid); } System.out.println(mapToString(map)); } private static String mapToString(SortedMap<Integer, Integer> map) { // TODO Auto-generated method stub StringBuilder builder = new StringBuilder(); for (SortedMap.Entry<Integer,Integer>e:map.entrySet()){ builder.append(e.getKey()).append( " " ).append(e.getValue()).append( "\r" ); } return builder.toString(); } private static void addPare(SortedMap<Integer, Integer> map, String[] mid) { // TODO Auto-generated method stub int key = Integer.parseInt(mid[ 0 ]); int value = http://www.mamicode.com/Integer.parseInt(mid[ 1 ]); if (map.containsKey(key)){ map.put(key, map.get(key) + value); } else { map.put(key, value); } } } |
数据表记录包含表索引和数值,请对表索引相同的记录进行合并,即将相同索引的数值进行求和运算,输出按照key值升序进行输出。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。