21xrx.com
2024-11-05 19:43:54 Tuesday
登录
文章检索 我的文章 写文章
C++实现集合交集操作
2023-06-25 20:16:13 深夜i     --     --
C++ 集合 交集操作

集合操作是计算机科学中常见的一种操作。在C++中,实现集合交集操作可以使用STL中的map容器。map是一种关联容器,允许用户将键值对存储在其中,支持快速查找和访问。

首先,我们需要定义两个map容器,分别存储两个集合中的元素。例如,我们可以定义如下两个map容器:


map<int, int> setA;

map<int, int> setB;

然后,我们可以使用for循环将元素插入到两个set容器中:


for(int i = 0; i < sizeA; i++){

  int num;

  cin >> num;

  setA[num] = 1;

}

for(int i = 0; i < sizeB; i++){

  int num;

  cin >> num;

  setB[num] = 1;

}

接下来,我们可以使用一个新的map容器,将两个集合的交集存储在其中。我们需要遍历一个set容器,在另一个set容器中查找元素。如果该元素在另一个set中也存在,则将其插入到新的map容器中。


map<int, int> intersection;

for(auto itA = setA.begin(); itA != setA.end(); itA++){

  if(setB.find(itA->first) != setB.end()){

    intersection[itA->first] = 1;

  }

}

最后,我们可以遍历新的map容器,打印出交集中的所有元素:


for(auto it = intersection.begin(); it != intersection.end(); it++){

  cout << it->first << " ";

}

完整的交集实现代码如下:


#include <iostream>

#include <map>

using namespace std;

int main(){

  int sizeA, sizeB;

  cin >> sizeA >> sizeB;

  map<int, int> setA;

  map<int, int> setB;

  for(int i = 0; i < sizeA; i++){

    int num;

    cin >> num;

    setA[num] = 1;

  }

  for(int i = 0; i < sizeB; i++){

    int num;

    cin >> num;

    setB[num] = 1;

  }

  map<int, int> intersection;

  for(auto itA = setA.begin(); itA != setA.end(); itA++){

    if(setB.find(itA->first) != setB.end()){

      intersection[itA->first] = 1;

    }

  }

  for(auto it = intersection.begin(); it != intersection.end(); it++){

    cout << it->first << " ";

  }

  return 0;

}

在实际应用中,我们可以根据具体要求定制不同的集合操作算法,从而更好地使用C++中的STL容器。

  
  

评论区

{{item['qq_nickname']}}
()
回复
回复