数据表记录包含表索引和数值,请对表索引相同的记录进行合并,即将相同索引的数值进行求和运算,输出按照key值升序进行输出

来源:互联网 发布:声波透射法数据分析 编辑:程序博客网 时间:2024/05/16 12:37

输入描述:

先输入键值对的个数然后输入成对的index和value值,以空格隔开

输出描述:

输出合并后的键值对(多行)

示例1

输入

40 10 21 23 4

输出

0 31 23 4

//C++ //C++,用stl中的map
#include<iostream>
#include<map>
usingnamespace std;
 
intmain()
{
    intn;
    while(cin >> n){
        map<int,int> m;
        while(n--){
            intkey,value;
            cin >> key >> value;
            if(!m[key]){
                m[key] = value;
            }
            elsem[key] += value;//不存在时赋值,存在时累加
        }
        //map内部本身就是按照key的大小顺序进行存储的
        for(map<int,int>::iterator it=m.begin();it!=m.end();++it){
            cout << it->first << " "<< it->second << endl;
        }
    }
    return0;
}
阅读全文
0 0