カテゴリー【C/C++】
【C++】2つのvector配列を比較して両方に共通する要素を取り出す【set_intersection】
POSTED BY
2023-01-14
2023-01-14

C++には2つのvector配列を比較して両方に共通する要素を取り出してくれる便利な関数set_intersectionがある。
これは、たとえば2人の旅行者が旅程を立てて、立ち寄る駅をリスト化した場合、この関数を使えば、2人が共通で立ち寄る駅は〇駅で、それぞれ〇番目に立ち寄る駅である、などと算出できる。
実践してみたサンプルソースは以下。
C/C++ | std_set_intersection.cpp | GitHub Source |
//2人の旅程を比較し立ち寄る同じ駅を抽出するサンプル #include <iostream> #include <vector> #include <unordered_map> #include <string> #include <iterator> #include <algorithm> int main(void) { std::vector<std::string> ryotei_1 = {"新宿", "西武新宿", "中井", "所沢", "本川越", "川越", "大宮", "池袋"}; std::vector<std::string> ryotei_2 = {"飯能", "所沢", "池袋", "上野", "秋葉原", "新宿", "中野", "阿佐ヶ谷"}; //インデックスマップを作成 map[駅名] = 配列インデックス std::unordered_map<std::string, int> ryotei_1_map = std::unordered_map<std::string, int>(); std::unordered_map<std::string, int> ryotei_2_map = std::unordered_map<std::string, int>(); int i = 0; std::for_each(ryotei_1.begin(), ryotei_1.end(), [&](auto &c) { ryotei_1_map[c] = i++; }); i = 0; std::for_each(ryotei_2.begin(), ryotei_2.end(), [&](auto &c) { ryotei_2_map[c] = i++; }); //立ち寄る同じ駅を抽出(ryotei_comに入る) //対象配列はあらかじめソートしておかないと機能しない※重要 std::vector<std::string> ryotei_com = std::vector<std::string>(); std::sort(ryotei_1.begin(), ryotei_1.end()); std::sort(ryotei_2.begin(), ryotei_2.end()); std::set_intersection(ryotei_1.begin(), ryotei_1.end(), ryotei_2.begin(), ryotei_2.end(), std::inserter(ryotei_com, ryotei_com.end())); //結果サマリーを出力 std::cout << "<2人が両方とも立ち寄る駅>" << std::endl; std::for_each(ryotei_com.begin(), ryotei_com.end(), [&](auto &c) { std::cout << c << " : Aさんが " << ryotei_1_map[c] + 1 << " 番目、Bさんが " << ryotei_2_map[c] + 1 << " 番目に立ち寄る駅。" << std::endl; }); }
コンパイル、実行結果
g++ std_set_intersection.cpp ./a.out <2人が両方とも立ち寄る駅> 所沢 : Aさんが 4 番目、Bさんが 2 番目に立ち寄る駅。 新宿 : Aさんが 1 番目、Bさんが 6 番目に立ち寄る駅。 池袋 : Aさんが 8 番目、Bさんが 3 番目に立ち寄る駅。
元の旅程リストの駅名をキーにした配列インデックスをunordered_mapに保存しておき、共通駅抽出ができたらそのリストから駅名キーをマップから配列インデックスを取得し案内している。色々な業種で実用シーンの多い機能である。
set_intersectionにかける前に、元配列は必ずソートしておかないと機能しない点に注意。
Android
iPhone/iPad
Flutter
MacOS
Windows
Debian
Ubuntu
CentOS
FreeBSD
RaspberryPI
HTML/CSS
C/C++
PHP
Java
JavaScript
Node.js
Swift
Python
Amazon/AWS
CORESERVER
Google
仮想通貨
LINE
OpenAI/ChatGPT
IBM Watson
Microsoft Azure
Xcode
VMware
MySQL
PostgreSQL
Redis
Groonga
Git/GitHub
Apache
nginx
Postfix
SendGrid
Hackintosh
Hardware
Fate/Grand Order
ウマ娘
将棋
ドラレコ
※本記事は当サイト管理人の個人的な備忘録です。本記事の参照又は付随ソースコード利用後にいかなる損害が発生しても当サイト及び管理人は一切責任を負いません。
※本記事内容の無断転載を禁じます。
※本記事内容の無断転載を禁じます。
【WEBMASTER/管理人】
自営業プログラマーです。お仕事ください!ご連絡は以下アドレスまでお願いします★
☆ServerNote.NETショッピング↓
ShoppingNote / Amazon.co.jp
☆お仲間ブログ↓
一人社長の不動産業務日誌
【キーワード検索】
【最近の記事】【全部の記事】
【Xcode】古いiOSバージョンシミュレータを導入するApple Developer Program有料メンバーシップでアプリをApp Storeで配信するまで【2】
Apple Developer Program有料メンバーシップでアプリをApp Storeで配信するまで【1】
¥x16進形式のログをデコードして表示する
CGIプログラムで操作した/tmp内ファイルが見つからない場合
【Xcode】No such module GoogleMobileAdsの対処法
【Swift UI】CocoaPodsを導入してGoogle Mobile SDKを使う
UbuntuにPHPを導入しMariaDBに接続するメモ
【Swift UI】フォントのデフォルトサイズはいくつか
【Swift UI】Cannot assign to property: self is immutableの対処法
【人気の記事】【全部の記事】
【Windows10】リモートデスクトップ間のコピー&ペーストができなくなった場合の対処法Windows版Google Driveが使用中と言われアンインストールできない場合
進研ゼミチャレンジタッチをAndroid端末化する
【C/C++】小数点以下の切り捨て・切り上げ・四捨五入
Androidホームで左にスワイプすると出てくるニュース共を一切表示させない方法
【Javascript】JSON配列内にある特定要素の取得法【Node.js】
OpenAIのGPT-4 APIの順番待ちリストに参加する
Googleスプレッドシートを編集したら自動で更新日時を入れる
Googleファミリーリンクで子供の端末の現在地がエラーで取得できない場合
【Apache】サーバーに同時接続可能なクライアント数を調整する
【カテゴリーリンク】
Android
iPhone/iPad
Flutter
MacOS
Windows
Debian
Ubuntu
CentOS
FreeBSD
RaspberryPI
HTML/CSS
C/C++
PHP
Java
JavaScript
Node.js
Swift
Python
Amazon/AWS
CORESERVER
Google
仮想通貨
LINE
OpenAI/ChatGPT
IBM Watson
Microsoft Azure
Xcode
VMware
MySQL
PostgreSQL
Redis
Groonga
Git/GitHub
Apache
nginx
Postfix
SendGrid
Hackintosh
Hardware
Fate/Grand Order
ウマ娘
将棋
ドラレコ