牛客网-合并表记录(c++)

题目描述

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

输入描述:

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

输出描述:

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

#include<iostream>
#include<map>
using namespace std;
int main()
{
    map<int, int> mapA;
    int num;
    int k;
    int v;
    cin >>num;
    for(int i = 0; i < num; i++)
    {
        cin>>k>>v;
        auto ret = mapA.insert({k,v});
        if(!ret.second)
        {
            mapA[k] += v; 
        }
    }
    for(auto& v: mapA)
    {
        cout << v.first << " " << v.second << endl;
    }
    return 0;
}
发布了18 篇原创文章 · 获赞 3 · 访问量 3661

猜你喜欢

转载自blog.csdn.net/qq_25677349/article/details/103965200