剔除list中相同的结构体数据,有三个思路:
1、两层循环,逐个比较

2、使用set容器来剔除

3、使用unique方法去重

  1. // deduplication.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include <list>
  4. #include <set>
  5. #include <iostream>
  6. #include <algorithm>
  7. #include <vector>
  8. #include <tchar.h>
  9. using namespace std;
  10. struct tagRecentGameItem
  11. {
  12. std::wstring strGameCode;
  13. std::wstring strServerID;
  14. __int64 nTime;
  15. tagRecentGameItem()
  16. : strGameCode(L"")
  17. , strServerID(L"")
  18. , nTime(0)
  19. {
  20. }
  21. bool operator < (const tagRecentGameItem& right) const
  22. {
  23. if (this->nTime > right.nTime)
  24. {
  25. return true;
  26. }
  27. if (this->nTime == right.nTime)
  28. {
  29. //compare函数在>时返回1,<时返回-1,==时返回0
  30. return this->strGameCode.compare(right.strGameCode) < 0;
  31. }
  32. return false;
  33. }
  34. bool operator == (const tagRecentGameItem& right) const
  35. {
  36. bool bEqual = false;
  37. //_tcsicmp不区分大小写,wcscmp区分大小写
  38. bEqual = ( 0 == _tcsicmp(this->strGameCode.c_str(), right.strGameCode.c_str()) );
  39. bEqual &= ( 0 == _tcsicmp(this->strServerID.c_str(), right.strServerID.c_str()) );
  40. return bEqual;
  41. }
  42. };
  43. //
  44. typedef std::list<tagRecentGameItem> listRecentGame;
  45. typedef std::set<tagRecentGameItem> setRecentGame;
  46. //
  47. listRecentGame m_LocalList;
  48. listRecentGame m_RemoteList;
  49. setRecentGame m_setGames;
  50. //打印结果
  51. void print_result(listRecentGame& items)
  52. {
  53. listRecentGame::iterator iter = items.begin();
  54. for (iter; iter!=items.end(); ++iter)
  55. {
  56. printf("gameCode: %ls\n", iter->strGameCode.c_str());
  57. }
  58. printf("\n");
  59. }
  60. //逐个比较
  61. void deduplication1(listRecentGame& items)
  62. {
  63. printf("method :deduplication1\n");
  64. items.sort();//需要重载操作符<
  65. listRecentGame::iterator itrB = items.begin();
  66. listRecentGame::iterator itrE = items.end();
  67. listRecentGame::iterator itr;
  68. for (itrB; itrB != itrE; ++itrB)
  69. {
  70. itr = itrB;
  71. ++itr;
  72. for(itr; itr != itrE;)
  73. {
  74. if (*itr == *itrB)
  75. {
  76. items.erase(itr++);
  77. }
  78. else
  79. {
  80. ++itr;
  81. }
  82. }
  83. }
  84. //打印结果
  85. print_result(items);
  86. }
  87. //利用set容器特性去重
  88. void deduplication2(listRecentGame& items)
  89. {
  90. printf("method :deduplication2\n");
  91. listRecentGame::iterator iter1 = items.begin();
  92. listRecentGame::iterator iter2 = items.end();
  93. for (iter1; iter1 != iter2; ++iter1)
  94. {
  95. //需要重载操作符<
  96. m_setGames.insert(*iter1);
  97. }
  98. //再写回list
  99. items.clear();
  100. setRecentGame::iterator pos = m_setGames.begin();
  101. for (pos; pos!=m_setGames.end(); ++pos)
  102. {
  103. items.push_back(*pos);
  104. }
  105. //打印结果
  106. print_result(items);
  107. }
  108. //stl的unique方法去重
  109. void deduplication3(listRecentGame& items)
  110. {
  111. printf("method :deduplication3\n");
  112. //unique函数功能是去除相邻的重复元素,注意是相邻,所以必须先使用sort函数。
  113. items.sort();
  114. //unique必须重载==操作符
  115. listRecentGame::iterator new_end = unique(items.begin(), items.end());
  116. items.erase(new_end, items.end());
  117. //打印结果
  118. print_result(items);
  119. }
  120. //
  121. int _tmain(int argc, _TCHAR* argv[])
  122. {
  123. //装载本地记录
  124. tagRecentGameItem item;
  125. memset(&item, 0, sizeof(item));
  126. item.strGameCode = L"abc";
  127. item.strServerID = L"s31";
  128. item.nTime = 20160501183417;
  129. m_LocalList.push_back(item);
  130. memset(&item, 0, sizeof(item));
  131. item.strGameCode = L"bcd";
  132. item.strServerID = L"s32";
  133. item.nTime = 20160501183418;
  134. m_LocalList.push_back(item);
  135. memset(&item, 0, sizeof(item));
  136. item.strGameCode = L"cde";
  137. item.strServerID = L"s33";
  138. item.nTime = 20160501183419;
  139. m_LocalList.push_back(item);
  140. memset(&item, 0, sizeof(item));
  141. item.strGameCode = L"def";
  142. item.strServerID = L"s34";
  143. item.nTime = 20160501183420;
  144. m_RemoteList.push_back(item);
  145. //装载远程记录
  146. memset(&item, 0, sizeof(item));
  147. item.strGameCode = L"abc";
  148. item.strServerID = L"s31";
  149. item.nTime = 20160501183417;
  150. m_RemoteList.push_back(item);
  151. memset(&item, 0, sizeof(item));
  152. item.strGameCode = L"bcd";
  153. item.strServerID = L"s32";
  154. item.nTime = 20160501183418;
  155. m_RemoteList.push_back(item);
  156. memset(&item, 0, sizeof(item));
  157. item.strGameCode = L"cde";
  158. item.strServerID = L"s33";
  159. item.nTime = 20160501183419;
  160. m_RemoteList.push_back(item);
  161. memset(&item, 0, sizeof(item));
  162. item.strGameCode = L"def0";
  163. item.strServerID = L"s34";
  164. item.nTime = 20160501183420;
  165. m_RemoteList.push_back(item);
  166. //合并到一个list
  167. m_LocalList.insert(m_LocalList.begin(), m_RemoteList.begin(), m_RemoteList.end());
  168. deduplication1(m_LocalList);
  169. deduplication2(m_LocalList);
  170. deduplication3(m_LocalList);
  171. system("pause");
  172. return 0;
  173. }

运行结果:

需要注意的地方:

STL中的排序都是默认使用小于号来排序。因此,在对结构体排序时,我们就需要重载小于号!比如:set容器在执行insert操作时,必须重载操作符<。另外,unique函数功能是去除相邻的重复元素,而在执行unique操作时必须重载操作符==。

https://blog.csdn.net/hellokandy/article/details/51333942

剔除list中相同的结构体数据的更多相关文章

  1. GPGPU OpenCL使用结构体数据

    OpenCL编程中可以使用结构体,只需要在核函数kernel中提供同样的结构体申明就可以啦. 如果在主函数中定义了结构体: typedef struct studentNode{ int age; f ...

  2. 计算机二级-C语言-对结构体数据进行求平均值。对结构体数据进行比较处理。

    //函数fun的功能是:计算形参x所指数组中N个数的平均值(规定所有数均为正数),作为函数返回,并将大于平均值的数放在形参y所指数组中,在主函数中输出. //重难点:对结构体数据进行求平均值. #in ...

  3. 如何系统学习C 语言(中)之 结构体篇

    1,结构体 在前面我们知道变量和数组都可以用来存储数据,变量用来存储单个数据,数组可以用来存储一组同类型的数据,但你有没有发现--它们都只适合单一属性的数据.那现实生活中,很多对象都是具有多属性的.例 ...

  4. MFC中的NMHDR结构体和NMUPDOWN结构体

    建立spin控件,创建UDN_DELTAPOS一个消息函数后: void CSpinDlg::OnDeltaposSpin1(NMHDR* pNMHDR, LRESULT* pResult) { NM ...

  5. C语言中 不定义结构体变量求成员大小

    所谓的求成员大小, 是求成员在该结构体中 用 sizeof(结构体名.结构体成员名) 求来的. 很多时候我们需要知道一个结构体成员中的某个成员的大小, 但是我们又不需要定义该结构体类型的变量(定义的话 ...

  6. 问题解决——在结构体中使用set保存结构体数据

    =====================声明========================== 本文原创,转载请明确的注明出处和作者,并保持文章的完整性(包括本声明部分). 本文链接:http:/ ...

  7. 【2016-08-18】转载:总结C++中几种结构体初始化的方法

    作者:Ac_Von 博客地址:http://www.cnblogs.com/vongang/ 文章地址:http://www.cnblogs.com/vongang/archive/2011/07/3 ...

  8. Swift中元组(Tuples),结构体(Struct),枚举(Enums)之间的区别

    Swift有许多种存储数据方式,你可以用枚举(enums),元组(tuples),结构体(structs),类(classes),在这篇文章中我们将比较枚举.元组.结构体之间区别,首先从最简单的开始- ...

  9. OC中常见的结构体,以及NSNumber、NSValue、NSDate的使用

    常见的结构体 NSPoint和CGPoint NSSize和CGSize NSRect 和 CGRect NSPoint和CGPoint的使用 NSPoint和CGPoint是同义的 typedef ...

随机推荐

  1. [Javascript] Iterate Over Items with JavaScript's for-of Loop

    In this lesson we will understand the For Of loop in Javascript which was introduced in ES6. The for ...

  2. php图像处理(thinkphp框架有相对强大的图像处理功能)

    php图像处理(thinkphp框架有相对强大的图像处理功能) 一.总结 1.php处理图像:php处理图像需要安装外库(gd库) 2.gd库函数可以非常完美的操作图像:安装好库之后,这个库里面的函数 ...

  3. Injection of autowired dependencies failed; autowire 自动注入失败,测试类已初始化过了Spring容器。

    1 严重: StandardWrapper.Throwable org.springframework.beans.factory.BeanCreationException: Error creat ...

  4. Java中接口继承泛型接口

    在使用Mybatis做web开发时,每一个模块的数据持久层的接口都会定义:增删改查四个方法.我想为什么不新建一个Base接口来做所有数据持久层的父接口呢? 于是,我试验了一下,建立了一个泛型接口,里面 ...

  5. 【软件project】 文档 - 银行业务管理 - 需求分析

    ---------------------------------------------------------------------------------------------------- ...

  6. JS错误记录 - 记录上次登陆的用户名

    <script> //步骤 1.submit => 用户名存进cookie 2. onload => 从cookie读取用户名 window.onload = function ...

  7. Java基础学习总结(50)——Java事务处理总结

    一.什么是Java事务 通常的观念认为,事务仅与数据库相关. 事务必须服从ISO/IEC所制定的ACID原则.ACID是原子性(atomicity).一致性(consistency).隔离性(isol ...

  8. Android小经验

    转载自:http://mp.weixin.qq.com/s?__biz=MzA4MjU5NTY0NA==&mid=404388098&idx=1&sn=8bbbba7692dc ...

  9. HDU 1018 Big Number 数学题解

    Problem Description In many applications very large integers numbers are required. Some of these app ...

  10. OVS中对于用户层和datapath层的多个通道利用epoll进行控制

    这里先临时记录下代码流程,有待完好. static int construct(struct ofproto *ofproto_) { struct ofproto_dpif *ofproto = o ...