qsortを試してみると、私にとっては完璧に動作します。私はプログラム全体で関数ポインタを使用し、他のいくつかの機能(つまり、voidポインタなど)を使用しています。
ただし、要素を降順(つまり、昇順ではなく)に配置する必要があります。これを達成するために何ができますか?
コードは次のとおりです。
#include <iostream>
#include <cstdlib> // Required for qsort
#include <cstring>
using std::cout;
using std::endl;
int compare_strs( const void *arg1, const void *arg2 );
int compare_ints( const void* arg1, const void* arg2 );
int main()
{
char * shrooms[10] =
{
"Matsutake", "Lobster", "Oyster", "King Boletus",
"Shaggy Mane", "Morel", "Chanterelle", "Calf Brain",
"Pig's Ear", "Chicken of the Woods"
};
int nums[10] = {99, 43, 23, 100, 66, 12, 0, 125, 76, 2};
// The address of the array, number of elements
// the size of each element, the function pointer to
// compare two of the elements
qsort( (void *)shrooms, 10, sizeof( char * ), compare_strs );
qsort( (void *)nums, 10, sizeof( int * ), compare_ints );
// Output sorted lists
for ( int i = 0; i < 10; ++i )
cout << shrooms[i] << endl;
for ( int i = 0; i < 10; ++i )
cout << nums[i] << endl;
return 0;
}
int compare_ints( const void * arg1, const void * arg2 )
{
int return_value = 0;
if ( *(int *)arg1 < *(int *)arg2 )
return_value = -1;
else if ( *(int *)arg1 > *(int *)arg2 )
return_value = 1;
return return_value;
}
int compare_strs( const void * arg1, const void * arg2 )
{
return ( _stricmp( *(char **) arg1, *(char **) arg2 ) );
}
プログラムは昇順(つまり、Calf Brainで始まる)で出力されますが、私はそれをShaggy Mane(つまり、降順)で始めようとしています。どんな助けでも大歓迎です。