• 締切済み

STLのList.sortが上手く使えない

VC++2005のSTLの、List.sort()を使ってメンバ変数aでソートしたいのですが上手くいきません。 MSDNで"IComparerをオーバーロードしろ"と、書いてあったのを見て、 いろいろ調べて試してはみたのですが、理解不足のため全て失敗しました。 ネットに転がっているサンプルはC#のモノばかりでサッパリです。 調べる手段も分からず八方塞な状態です。どうかお力を貸してください。お願いします。 class TestList { protected: std::list<TestList*> RunList; int a; //この変数でソートする public: MakeList(TestList *test); //リストを"RunList"に登録する }; void main() { TestList Test(); //全てのリストはココに登録 Test->MakeList(new TestList()); Test->MakeList(new TestList()); Test->RunList.sort(); //←ココ。メンバ変数aでソートしたい } 【追記】MSDNの方法では"mscorlib.dll"が必要になります。 もし可能なら違う方法になったとしても、使うことなくソートできるなら、その方が良いです。

みんなの回答

  • Tacosan
  • ベストアンサー率23% (3656/15482)
回答No.3

#2 です. compareByA を static で宣言して, 使うときに &TestList::compareByA にすればいいはず.

satou386
質問者

お礼

Tacosanさん、ありがとうございます。きちんと動きました。 STLの他のソートに関してもこの方法が使えるようですね。

  • Tacosan
  • ベストアンサー率23% (3656/15482)
回答No.2

bool compareByA(const TestList *x, const TestList *y) { return x->a < y->a; } という関数を定義しておいて, Test->RunList.sort(compareByA); という手もありますね. もちろん compareByA からは TestList::a がアクセスできる必要があります. ところでこれ, main から TestList::RunList をアクセスできます?

satou386
質問者

補足

プレディケートですね。早速、試してみました。 しかし、クラスのメンバ関数内で、リストを保持するクラスのアドレス(TestList Test();のアドレス)を使って、リスト内でアクセスしようとすると『error C3867:関数呼び出しには引数リストがありません。』が出てしまいます。 どこがマズイのでしょうか? メイン関数では上手くいくのですが… class TestList //他のメンバは省略しています。 { protected: TestList *ListAdress; //自分が格納されているTestListクラスのアドレス public: bool compareByA(const TestList *x, const TestList *y) { return x->a < y->a; } void SortListA(); }; TestList::SortListA() { ListAdress->RunList.sort(ListAdress->compareByA); //←ココでエラー }

  • iyomante
  • ベストアンサー率60% (14/23)
回答No.1

std::list::sort()は operator< () をオーバーロードします。 ただポインタのリストの場合はこれはそのままでは使えないので、参考URLで近いことがやってあるようです。 ----------------------------------------- 変数一個でソートするだけならmultimapにしてみては #include<map> class TestList { protected: std::multimap<int, TestList*> RunList; int a; //この変数でソートする public: void MakeList(TestList *test); //リストを"RunList"に登録する }; void TestList::MakeList(TestList *test) { typedef std::pair<int, TestList*> type_it; RunList.insert(type_it(test->a, test)); }

参考URL:
http://rararahp.cool.ne.jp/cgi-bin/lng/vc/vclng.cgi?print+200312/03120061.txt
satou386
質問者

補足

->参考URLで近いことがやってあるようです。 回答、ありがとうございます。 「TestList*」を渡した時の「greater」の比較を「x > y」から「x->a > y->a」に変更しているのは、 何となく理解できました。しかし、具体的にどう書けばいいのか全く解りません。 リンク先を参考にして「クラス"TestList"」に『追加』した所、C2143などのエラーが出てダメでした。 #using <mscorlib.dll> #include<list> using namespace System; using namespace System::Collections::Generic; class TestList //他のメンバは省略しています。 { public: typedef TestList* ts; template<> greater<ts>::bool operator() (const ts &x, const ts &y) const { return x->a > y->a; } }; ----------------------------------------------- ->変数一個でソートするだけならmultimapにしてみては リスト実行中に、全リストのメンバaを書き換え、 さらに、1秒間あたり数十回ソートする必要があるので 向いてなさそうです。

関連するQ&A

専門家に質問してみよう