免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3861 | 回复: 10
打印 上一主题 下一主题

[C++] 把容器的字段值进行累加求和!求大神指导! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-11-05 14:54 |只看该作者 |倒序浏览
本帖最后由 zhanhorse 于 2013-11-06 11:10 编辑

根据vector<string> grp_cols字段,然后把vector<long> sum_cols字段值进行累加,不知道怎么实现。请大侠指导!

//存放结果表原始记录
typedef struct record_t
{
        vector<string> grp_cols;//此容器存储多个字段
        vector<long> sum_cols;//此容器存储需要合计的多个字段
}_record_t;

//存放结果表记录
typedef struct record_t_1
{
        vector<string> sum_cols; //保存所有维度的数据
}_record_t_1;


typedef        vector<_record_t> result_rec;  // 结果表原始的数据
typedef        vector<_record_t_1> result_rec1;  // 结果表的数据

class TA_SUM_BWT
{

private:
        result_rec _result_rec; // 结果表原始的数据
  result_rec_1 _result_rec_1; // 结果表的数据
};

把result_rec容器数据进行累加后,保存到result_rec1容器中。
现在的问题是如何这个容器的数据进行排序呢(由于这个容器的字段是不确定)
vector<string> grp_cols;//此容器存储多个字段

论坛徽章:
0
2 [报告]
发表于 2013-11-05 15:59 |只看该作者
嗯,大侠不在吗!

论坛徽章:
0
3 [报告]
发表于 2013-11-05 17:13 |只看该作者
第二个用map比较好
第一个vector循环,找到某个字段的值,比如key的值是value, 那就map[key] += value;

论坛徽章:
0
4 [报告]
发表于 2013-11-05 17:14 |只看该作者
vector<long> sum_cols;
可以用map<string, long>sum_cols; 来实现。

论坛徽章:
0
5 [报告]
发表于 2013-11-05 17:28 |只看该作者
本帖最后由 zhanhorse 于 2013-11-05 17:30 编辑

回复 4# sxcong


    用map匹配不是只能单个字段值匹配吗,我这个是多个字段进行匹配的喽,要多个字段同时满足,才进行累加的!

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
6 [报告]
发表于 2013-11-05 18:53 |只看该作者
回复 1# zhanhorse


    不是特别清楚你的需求,累加的功能调用std::accumulate这个算法来实现,特别的累加需求的话自己定义op函数来实现,由于判断需要额外的容器数据参数所以把op定义为仿函数更好,或者使用boost::bind,std::bind2st之类的方法把这个容器传到op函数中。

论坛徽章:
9
摩羯座
日期:2013-08-15 15:18:48狮子座
日期:2013-09-12 18:07:47金牛座
日期:2013-09-16 13:23:09辰龙
日期:2013-10-09 09:03:27白羊座
日期:2013-10-17 13:32:44子鼠
日期:2014-04-23 15:09:38戌狗
日期:2014-09-17 11:37:542015年亚洲杯之韩国
日期:2015-03-26 10:16:442015亚冠之武里南联
日期:2015-08-18 14:55:52
7 [报告]
发表于 2013-11-06 09:27 |只看该作者
能自己定义数据结构,却不能用自己定义的数据结构解决问题,那么这个数据结构本身是否有问题?
如果这个数据结构本身存在问题,那么你用一个可能有问题的东西进行提问,然后搞得大家一头雾水,不知所云;那还不如你来举一个例子,让别人来帮你定义数据结构。

论坛徽章:
6
技术图书徽章
日期:2013-11-13 11:11:27子鼠
日期:2014-02-20 17:54:13处女座
日期:2014-06-16 17:43:33午马
日期:2014-08-08 09:11:17未羊
日期:2014-08-10 11:57:072015年辞旧岁徽章
日期:2015-03-03 16:54:15
8 [报告]
发表于 2013-11-06 09:47 |只看该作者
把习题拿出来从头设计比较靠谱。

论坛徽章:
0
9 [报告]
发表于 2013-11-06 11:09 |只看该作者
littledick 发表于 2013-11-06 09:47
把习题拿出来从头设计比较靠谱。

这个不是习题,是需求!
已经想到解决方法,现在的问题是如何这个容器的数据进行排序呢(由于这个容器的字段是不确定)
vector<string> grp_cols;//此容器存储多个字段

论坛徽章:
6
技术图书徽章
日期:2013-11-13 11:11:27子鼠
日期:2014-02-20 17:54:13处女座
日期:2014-06-16 17:43:33午马
日期:2014-08-08 09:11:17未羊
日期:2014-08-10 11:57:072015年辞旧岁徽章
日期:2015-03-03 16:54:15
10 [报告]
发表于 2013-11-06 11:56 |只看该作者
如果_record_t中字符数组下标和整形数组下标是一一对应的话,那么这个类型这样设计会容易操作
  1. struct _single_record
  2. {
  3.     std::string grp_col;
  4.     long sum_col;
  5. }

  6. typedef vector<_single_record> _record_t
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP