c-library の qsort 関数を学習してみましたstdlib
。これは、でも提供されc++
ます。しかし、文字列の並べ替えにそれらを使用する方法がわかりませんc++
。sizeof()
オペレーターのパラメーターがどうあるべきか、compare_str
コードが正しいかどうかがわかりません。私はこのコードを試しました:
#include<iostream>
#include<cstdlib>
using namespace std;
#include<string>
int compare_str( const void *a, const void *b){
string obj = (const char*)a;
string obj1 = (const char*)b;
return obj.compare(obj1);
}
int main(){
string obj[4] = {"fine", "ppoq", "tri", "get"};
qsort(obj, 4, sizeof(obj[0].length()), compare_str);
for( int i=0; i<4; i++)
cout<<obj[i]<<endl;
return 0;
}
私の出力は次のとおりです。
ppoq
tri
get
fine
私はエラーを理解することができません。助けてください。