HJ8 合并表记录 HJ08

HJ8合并表记录

#include<iostream>
#include<map>
using namespace std;

int main(int argc, char *argv[]) {
    int k, v;
    int n = 0;
    std::map<int, int> m;
    
    cin >> n;
    while (n-- > 0) {
        cin >> k;
        cin >> v;
        if (m.find(k) == m.end()) {
            m[k] = v;
        } else {
            m[k] += v;
        }
    }
    for (auto it = m.begin(); it != m.end(); ++it) {
        std::cout << it->first << " " << it->second << "\n";
    }
    return 0;
}

实际读取数据一般是从文件, 用std::ifstream,  需要引入fstream头文件 #include <fstream>

 main.cpp

#include <iostream>
#include <fstream>
#include <sstream>
#include <map>

class HJ08 {
public:
    static std::string file_get_contents(const std::basic_string<char>& path) {
        std::ifstream file;
        file.open(path, std::ios_base::in);
        if (!file.is_open()) {
            std::cout << "打开\"" << path << "\"失败";
            return "";
        }
        std::stringstream s;
        s << file.rdbuf();
        file.close();
        return s.str();
    }

    static std::map<int, int> mergedPairs(const std::basic_string<char>& path) {
        std::map<int, int> m;
        std::ifstream ifs;

        ifs.open(path, std::ios_base::in);
        if (!ifs.is_open()) {
            std::cout << "打开\"" << path << "\"失败";
            return m;
        }
        int n = 0;
        ifs >> n;

        int k, v;
        while (n-- > 0) {
            ifs >> k;
            ifs >> v;
            if (m.find(k) == m.end()) {
                m[k] = v;
            } else {
                m[k] += v;
            }
        }
        ifs.close();
        return m;
    }
};

int main() {
    // std::string content = HJ08::file_get_contents("../input_01.txt");
    // std::cout << content;
    std::map<int, int> m;
    m = HJ08::mergedPairs("../input_01.txt");

    // std::map<int, int>::const_iterator
    for (auto it = m.begin(); it != m.end(); ++it) {
        std::cout << it->first << " " << it->second << "\n";
    }
//    for (auto &pair : m) {
//        std::cout << pair.first << " " << pair.second << "\n";
//    }

    return 0;
}

        pair<int, int>i;
        cin >> i.first >> i.second;
        m[i.first] += i.second;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fareast_mzh

打赏个金币

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值