カテゴリー【C/C++】
通常のC言語配列にstd::for_each,find_if等のC++ラムダ式ループを適用する
POSTED BY
2023-01-19
2023-01-19

std::for_each,find_if,sort,accumulate等のC++ラムダ式ループ構文はvector.begin(),end()だけでなく、通常のC言語配列に対してもループできる。
この場合はvector.begin()の代わりに配列の先頭アドレス=array[5]ならarray、vector.end()の代わりに配列の先頭アドレス+要素数=array[5]ならarray + 5と記載するだけでよい。
サンプルは以下。
C/C++ | ramda_loop_for_carray.cpp | GitHub Source |
#include <iostream> #include <cstring> #include <algorithm> int main(void) { struct { char key[32]; char value[64]; }arrays[8] = { {"きー1", "ばりゅー1"}, {"きー2", "ばりゅー2"}, {"きー3", "ばりゅー3"}, {"きー4", "ばりゅー4"}, {"きー5", "ばりゅー5"}, {"きー6", "ばりゅー6"}, {"きー7", "ばりゅー7"}, {"きー8", "ばりゅー8"}, }; //ループ出力 std::for_each(arrays, arrays + 8, [&](auto &c) { std::cout << c.key << "+" << c.value << std::endl; }); //値に5を含む要素の検索 auto itr = std::find_if(arrays, arrays + 8, [&](auto &c) { return strstr(c.value, "5") ? true:false; }); if(itr != arrays + 8) { //発見した場合itrは要素のアドレス: itr->key, itr->valueでアクセス可能 int i = std::distance(arrays, itr); std::cout << "arrays[" << i << "].valueに5発見" << std::endl; } return 0; }
コンパイル、実行結果
g++ ramda_loop_for_carray.cpp ./a.out きー1+ばりゅー1 きー2+ばりゅー2 きー3+ばりゅー3 きー4+ばりゅー4 きー5+ばりゅー5 きー6+ばりゅー6 きー7+ばりゅー7 きー8+ばりゅー8 arrays[4].valueに5発見
ループで渡ってくる参照引数cは対象配列内要素そのものなので、構造体配列なら.で各値にアクセス可能。
find_ifも適用可能で、条件を満たす要素が見つかったらfind_ifループを抜ける。
itrには発見要素のアドレスが返るので、itr→key、itr→valueでアクセス可能。未発見ならvector.end()に代わりarrays + 8がitrに返る。
何番目の要素かstd::distanceにitrを指定して配列のindexも取得できる。
【利用料0円!】<法人携帯>日本最大級のBtoB見積比較サービス【一括.jp】

法人携帯の導入をご検討なら【法人携帯 一括.jp】
一括.jp/法人携帯では、法人携帯の導入をお考えのお客...【READ MORE】
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
IBM Watson
Microsoft Azure
Xcode
VMware
MySQL
PostgreSQL
Redis
Groonga
Git/GitHub
Apache
nginx
Postfix
SendGrid
Hackintosh
Hardware
Fate/Grand Order
ウマ娘
将棋
※本記事は当サイト管理人の個人的な備忘録です。本記事の参照又は付随ソースコード利用後にいかなる損害が発生しても当サイト及び管理人は一切責任を負いません。
※本記事内容の無断転載を禁じます。
※本記事内容の無断転載を禁じます。
【キーワード検索】
ミラノ発のレザーブランド 【BONAVENTURA・ボナベンチュラ】
ポイント最大6%還元!ファッション通販サイト MAGASEEK
リモート&週1〜OK!フリーランスや副業ワーカー向け案件探し【SOKUDAN】
誰にも気づかれずに薄毛にさよなら!大人気の女性向けおしゃれ増毛サービス【SKINA CARE】
Webサイト・データベースを遠隔バックアップ【torocca!】
無料で使える クラウド請求書・見積書・納品書管理サービス Misoca(みそか)
短時間での作業が可能!ゴキブリ(害虫)駆除サービス【ダスキン】無料診断申込み
ココゾの元気がほしい男性のための【クラチャイダムゴールド液】
メディアでも多数紹介♪プレゼントにも最適な【アームボーテ】
日本酒の糀エキスを配合したオールインワンジェル!【美酒爛】

ポイント最大6%還元!ファッション通販サイト MAGASEEK

リモート&週1〜OK!フリーランスや副業ワーカー向け案件探し【SOKUDAN】

誰にも気づかれずに薄毛にさよなら!大人気の女性向けおしゃれ増毛サービス【SKINA CARE】

Webサイト・データベースを遠隔バックアップ【torocca!】

無料で使える クラウド請求書・見積書・納品書管理サービス Misoca(みそか)

短時間での作業が可能!ゴキブリ(害虫)駆除サービス【ダスキン】無料診断申込み

ココゾの元気がほしい男性のための【クラチャイダムゴールド液】

メディアでも多数紹介♪プレゼントにも最適な【アームボーテ】

日本酒の糀エキスを配合したオールインワンジェル!【美酒爛】

【最近の記事】【全部の記事】
PowerPointでテキストを左右反転するにはオンボードグラフィックスと外付けビデオカードを同時利用してデュアルディスプレイにする
EaseUS RecExpertsで画面を録画する
【MySQL】テーブル定義を確認してインデックスを操作する【MariaDB】
通常のC言語配列にstd::for_each,find_if等のC++ラムダ式ループを適用する
【C/C++】処理系に依存しない64ビットフラグ演算集【保存版】
【C++】2つのvector配列を比較して両方に共通する要素を取り出す【set_intersection】
【Node.js】ビットコイン(BTC)およびイーサリアム(ETH)の日本円(JPY)レートを取得する
【Node.js】BTC←→SATOSHIおよびETH←→WEIの相互変換を行う
【Node.js】文字列を後から復元できる可逆の暗号化にかける
【人気の記事】【全部の記事】
進研ゼミチャレンジタッチをAndroid端末化する【Windows10】リモートデスクトップ間のコピー&ペーストができなくなった場合の対処法
Googleスプレッドシートを編集したら自動で更新日時を入れる
Googleスプレッドシートで図形をコピーして使いまわすには
【Javascript】JSON配列内にある特定要素の取得法【Node.js】
Windows版Google Driveが使用中と言われアンインストールできない場合
Googleファミリーリンクで子供の端末の現在地がエラーで取得できない場合
【Linux共通】プロキシサーバーの利用設定
Androidホームで左にスワイプすると出てくるニュース共を一切表示させない方法
Ubuntuで固定IPアドレスを使う設定をする
【カテゴリーリンク】
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
IBM Watson
Microsoft Azure
Xcode
VMware
MySQL
PostgreSQL
Redis
Groonga
Git/GitHub
Apache
nginx
Postfix
SendGrid
Hackintosh
Hardware
Fate/Grand Order
ウマ娘
将棋