質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

3回答

1608閲覧

C++でJavaのcontainsAllを実現したい

tatataro

総合スコア23

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2017/06/11 10:10

###前提・実現したいこと
C++のstd::setでJavaのcontainsAllを実現しようとしているのですが,イテレータの値を使ってset内を検索しようとすると以下のエラーが出ます.
おそらく変換ができていないですが,解決方法がわかりませんでした.

お分かりになる方いましたら,ご教示ください.
よろしくお願いします.

Debian 8.7
gcc 4.9.2
g++ 4.9.2
###発生している問題・エラーメッセージ

test.cc: In function ‘int main()’: test.cc:11:20: error: could not convert ‘st1.std::set<_Key, _Compare, _Alloc>::find<int, std::less<int>, std::allocator<int> >((* & it.std::_Rb_tree_const_iterator<_Tp>::operator*<int>()))’ from ‘std::set<int>::iterator {aka std::_Rb_tree_const_iterator<int>}’ to ‘bool’ if (st1.find(*it)) cnt++; ^

###該当のソースコード

#include <iostream> #include <set> int main() { std::set< int > st1{1, 2, 3}; std::set< int > st2{1, 2}; int cnt = 0; for (auto it = st2.begin(); it != st2.end(); it++) if (st1.find(*it)) cnt++; if (cnt == st2.size()) std::cout << "st2 all contans in st1" << std::endl; return 0; }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

std::includesでイッパツでしょ。

C++

1// #incude <algorithm> 2bool result = std::includes(set1.begin(), set1.end(), set2.begin(), set2.end());

投稿2017/06/11 23:01

episteme

総合スコア16614

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

"st2st1を含むか検査する"と解釈して回答します。

std::set::findstd::set::iteratorまたはstd::set::const_iteratorを返し、それらの型は bool へのキャストについて定義しませんので、変換出来ずエラーとなります。提示されたコードを前掲の前提の基、極力変えずに修正するならば、以下のようになるでしょう。

cpp

1#include <iostream> 2#include <set> 3 4int main() { 5 std::set< int > st1{1, 2, 3}; 6 std::set< int > st2{1, 2}; 7 std::size_t cnt = 0; 8 9 for (auto it = st2.begin(); it != st2.end(); it++) 10 if (st1.end()!=st1.find(*it)) cnt++; 11 12 if (cnt == st1.size()) 13 std::cout << "st2 contains st1" << std::endl; 14 15 return 0; 16}

尚、C++11以降であれば、std::all_ofを使う事で、簡単に記述できます。

cpp

1#include <iostream> 2#include <set> 3 4int main() { 5 std::set< int > st1{1, 2, 3}; 6 std::set< int > st2{1, 2}; 7 8 if (std::all_of(std::begin(st1),std::end(st1),[&st2](const auto& x){return st2.end()!=st2.find(x);})) 9 std::cout << "st2 contains st1" << std::endl; 10}

投稿2017/06/11 11:54

kjfkhfhgx

総合スコア48

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tatataro

2017/06/11 12:22

プログラムまで書いていただきありがとうございます! countをsize_t型にする部分でなるほど、となりました. all_ofについては勉強不足でしたが,だいぶシンプルに書けるようなので勉強致します. ありがとうございました!
kjfkhfhgx

2017/06/12 05:58

私の上記回答では std::all_of に条件判定のラムダを渡していましたが、 episteme さんのおっしゃる通り、std::includes を使う事で、より意味合いとしても明快に、簡潔に記述できます。まずこちらを推めるべきでした。
guest

0

find でイテレータが返ってきているので、これをそのまま bool として使うことはできない、と言われているだけですね。

投稿2017/06/11 10:32

koko_u

総合スコア936

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tatataro

2017/06/11 11:57

以下のように変更することで希望通りのプログラムを作れました,ありがとうございます! この変更部分ですが,変数indexを作らずに無理なく書くことはできますでしょうか? もし別の良い書き方があるようでしたら教えていただけるとありがたいです. auto index = st1.find(*it); if (*index) cnt++;
koko_u

2017/06/11 12:08

> 以下のように変更することで希望通りのプログラムを作れました, setの要素として 0 が格納されている場合に問題になります。ご確認下さい。
tatataro

2017/06/11 12:19

その通りでしたので,ifの条件式を変更します. ご指摘ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問