Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
69 / 69 / 2
Регистрация: 10.05.2011
Сообщений: 173
1

Шаблон функции сравнения для qsort()

03.05.2013, 14:37. Просмотров 981. Ответов 1
Метки нет (Все метки)

Хочу отсортировать массив из int и из double с помощью qsort().
Для этого необходимо определить функцию сравнения элементов.
Думал попробовать сделать шаблон такой функции.
C++
1
2
3
4
5
6
7
8
9
10
11
template <class T>
int comp(const T *a,const T *b)
{
//  return *(double *)a - *(double *)b;
    if (*(T *)a < *(T *)b)
        return -1;
    else if (*(T *)a > *(T *)b)
        return 1;
    else
        return 0;
}
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int main(int argc, char* argv[])
{
    double num[] = {10.5, 4.3, 3.9, 6.7, 5.8, 7.1, 8.0};
    int i;
 
    qsort(num,7,sizeof(double),comp);
 
    for(i=0;i<7;i++)
        cout<<num[i]<<' ';
 
    getch();
    return 0;
}
После компиляции ругается [BCC32 Error] E2109 Not an allowed type везде где есть *(T *)a(или b).
Можно ли вообще так сделать, с помощью шаблонов? Не охота для каждого числового типа определять свою функцию.
Кстати почему если для массива из double определить такую функцию сравнения:
C++
1
2
3
4
int comp(const void *a,const void *b)
{
    return *(double *)a - *(double *)b;
}
То массив отсортирован след-им образом: 4.3, 3.9, 5.8, 6.7, 7.1 ,8.0, 10.5. Первые два не в том порядке.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
03.05.2013, 14:37
Ответы с готовыми решениями:

Шаблон функции qsort()
Здорова! Нужно реализовать шаблон функции qsort(). Скачал пример и никак не могу разобраться как...

Работа функции qsort - объяснить работу функции
#include&lt;iostream&gt; #include&lt;cstdlib&gt; int mysort(const void *arg1, const void *arg2); int main()...

Алгоритм работы функции qsort
Всем добрый день, у меня тут небольшая просьба. Кому не трудно, выложите пожалуйста простой...

Написать функцию сравнения двух структур (шаблон структуры задается произвольно)
ЗАДАНИЕ: Написать функцию сравнения двух структур (шаблон структуры задается произвольно). ...

1
Каратель
Эксперт С++
6593 / 4014 / 401
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
03.05.2013, 14:40 2
Цитата Сообщение от Я-Лис Посмотреть сообщение
Можно ли вообще так сделать, с помощью шаблонов? Не охота для каждого числового типа определять свою функцию.
use std::sort, Luke
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.05.2013, 14:40

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Написать функцию сравнения двух структур (шаблон структуры задается произвольно)
ЗАДАНИЕ: Написать функцию сравнения двух структур (шаблон структуры задается произвольно). ...

исправление функции qsort сортировки матрицы
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; #include &lt;conio.h&gt; #include...

Шаблон функции для подсчета значений в массиве
Всем доброго времени суток. Очень прошу помочь написать программу. Нужно создать шаблон функции...

Шаблон функции для удвоения максимального значения
Помогите написать программу : Напишите программу, которая использует шаблон функции для удвоения...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.