华为OJ-008

合并表记录

Posted by Shaun on April 7, 2018

题目描述

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

输入描述:

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

输出描述:

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

示例1

输入

4
0 1
0 2
1 2
3 4

输出

0 3
1 2
3 4

算法实现

实现1
//思路1:
#include <iostream>
#include <map>
using namespace std;
int main(int argc, const char * argv[]) {
    int n,key,value;
    map<int,int> m;
    while(cin>>n){
        m.clear();
        while(n--){
            cin>>key>>value;
            if(!m[key])
                m[key]=value;
            else
                m[key]+=value;
        }
        for(auto i=m.begin();i!=m.end();i++)
            cout<<i->first<<" "<<i->second<<endl;
    }
    return 0;
}

小结

小结