c++:對結構體容器中,重複的元素去重問題

今天在公司遇到一個問題,須要對容器存儲的結構體中的元素進行去重,這裏用到了sort與unique,頭文件須要加上algorithmios

 

#include <iostream>
#include <vector>
#include<algorithm>
using namespace std;
struct stu
{
  int id;
  bool operator<(const stu &s1)//重載<操做符
  {
    return (*this).id < s1.id;
  }
  bool operator==(const stu &s1)//重載==操做符
  {
    return (*this).id == s1.id;
  }
  bool operator>(const stu &s1)//重載>操做符
  {
    return (*this).id > s1.id;
  }
};
struct stuSort
{
  bool operator()(const stu &s1,const stu &s2)
  {
    return s1.id < s2.id;
  }
};
int main()
{
  vector<struct stu> s;
  struct stu p;
  for(int j = 0; j < 3; j++)
  {
    for(int i = 0; i < 5;i++)
    {
      p.id = i;
      s.push_back(p);
      cout << s[i].id;
    }
  }
  cout << endl;
  struct stuSort sortFunc;
  std::sort(s.begin(),s.end(),sortFunc);
  s.erase(unique(s.begin(),s.end()),s.end());
  for(int i = 0; i<s.size();i++)
    cout << s[i].id << endl;
  return 0;
}this

相關文章
相關標籤/搜索