zoukankan      html  css  js  c++  java
  • MergeRecord_C++中map的使用

    //============================================================================
    // Name        : TTTest.cpp
    // Author      : 
    // Version     :
    // Copyright   : Your copyright notice
    // Description : Hello World in C++, Ansi-style
    //============================================================================
    
    #include <iostream>
    #include <stdlib.h>
    #include <map>
    typedef struct TIME_STRU {
        int nIndex; /* 表索引 */
        int nValue; /**/
    } TABLE_RECORD;
    
    void MergeRecord(TABLE_RECORD* pOriRecord, int nOriRecordNum,
            TABLE_RECORD* pMergeRst, int* pnMergeRecordNum);
    
    using std::cout;
    using std::endl;
    using std::map;
    using std::make_pair;
    
    void MergeRecord(TABLE_RECORD* pOriRecord, int nOriRecordNum,
            TABLE_RECORD* pMergeRst, int* pnMergeRecordNum) {
        map<int, int> inMap;
    
        for (int i = 0; i < nOriRecordNum; ++i) {
            auto ret = inMap.insert(make_pair(pOriRecord[i].nIndex, pOriRecord[i].nValue));
            if(!ret.second) {
           // 或者直接+=即可 inMap[pOriRecord[i].nIndex]
    += pOriRecord[i].nValue); } } cout << inMap.size() << endl; cout << inMap[2] << endl; return; } int main() { // TABLE_RECORD pOriRecord[] = { { 1, 3 }, { 2, 3 }, { 2, 8 } }; // cout << pOriRecord[0].nIndex << endl; // // int nOriRecordNum = sizeof(pOriRecord) / sizeof(pOriRecord[0]); // cout << nOriRecordNum << endl; // // TABLE_RECORD* pMergeRst; // int nMergeRecordNum = 0; // int* pnMergeRecordNum = &nMergeRecordNum; // MergeRecord(pOriRecord, nOriRecordNum, pMergeRst, pnMergeRecordNum); int ttt = -123; char s[8] = { 0 }; itoa(ttt, s, 10); cout << s <<endl; return 0; }
  • 相关阅读:
    P2422 良好的感觉
    拉格朗日插值
    C# 中的委托和事件(详解)
    异步委托
    ManualResetEvent详解
    快速理解C#高级概念事件与委托的区别
    拉格朗日多项式
    oracle 插入一个从别处查询获得字段的值
    decode和nvl的用法
    C#将像素值转换为图片
  • 原文地址:https://www.cnblogs.com/xiaochou/p/MergeRecord_Cpp.html
Copyright © 2011-2022 走看看