华为-合并记录表

题目链接

https://www.nowcoder.com/practice/de044e89123f4a7482bd2b214a685201?tpId=37&tqId=21231&tPage=1&rp=&ru=/ta/huawei&qru=/ta/huawei/question-ranking

题目描述

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

输入描述: 

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

输出描述:

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

示例1

输入

复制

4
0 1
0 2
1 2
3 4

输出

复制

0 3
1 2
3 4

题解:

直接使用map

#include <iostream>
#include <map>
using namespace std;
int main(){
  int n;
  cin >> n;
  map <int, int> datalist;
  for(int i = 0; i < n; i++){
    int key, value;
    cin >> key >> value;
    if(!datalist[key]){
      datalist[key] = value;
    }
    else{
      datalist[key] += value;
    }
  }
  map <int, int>::iterator dl_iter;
  for(dl_iter = datalist.begin(); dl_iter != datalist.end(); dl_iter++){
    cout << dl_iter->first << " " << dl_iter->second << endl;
  }
  return 0;
}

 

已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页