2 / 2 / 0
Регистрация: 04.06.2013
Сообщений: 44
|
||||||
1 | ||||||
Почему компилятор ругается на использование шаблона (template)?10.04.2016, 15:23. Показов 1459. Ответов 12
Метки нет (Все метки)
В чем моя ошибка? Жду ответа с нетерпением.
0
|
10.04.2016, 15:23 | |
Ответы с готовыми решениями:
12
Использование шаблона template Почему ругается компилятор Почему ругается компилятор? почему компилятор не ругается? |
116 / 106 / 51
Регистрация: 29.03.2016
Сообщений: 480
|
|
10.04.2016, 15:31 | 2 |
чтобы массив добавить используйте T2 *a
0
|
2 / 2 / 0
Регистрация: 04.06.2013
Сообщений: 44
|
|
10.04.2016, 15:42 [ТС] | 3 |
Ser o Grey,
Ничего не изменилось
0
|
116 / 106 / 51
Регистрация: 29.03.2016
Сообщений: 480
|
|
10.04.2016, 16:00 | 4 |
Surges, а у вас сейчас точно на template ругается?
Добавлено через 5 минут а у вам не здесь случаем проблема int n[size]; Добавлено через 7 минут вы замечаете что в функции используете переменные не того типа?
0
|
2 / 2 / 0
Регистрация: 04.06.2013
Сообщений: 44
|
|
10.04.2016, 16:02 [ТС] | 5 |
Serg o Grey,
выводимый текст ошибок: Кликните здесь для просмотра всего текста
error C2672: 'quicksort': no matching overloaded function found
error C2782: 'void quicksort(T2 *,T1,T1)': template parameter 'T1' is ambiguous error C2784: 'void quicksort(T2 *,T1,T1)': could not deduce template argument for 'T1' from 'unsigned long' Из текста сообщений следует, что шаблон T1 не может догадаться, какой будет тип. Но разве это не очевидно, что должно быть "int" ?
0
|
116 / 106 / 51
Регистрация: 29.03.2016
Сообщений: 480
|
|
10.04.2016, 16:07 | 6 |
Сообщение было отмечено Surges как решение
Решение
const unsigned long nul = 0;
quicksort(n, nul, size - 1); Добавлено через 1 минуту правда у вас в программе есть еще ряд проблем, связанных с невозможностью функции распознать массив
1
|
2 / 2 / 0
Регистрация: 04.06.2013
Сообщений: 44
|
|
10.04.2016, 16:13 [ТС] | 7 |
Serg o Grey,
Большое спасибо, я понял, в чем было дело.
0
|
8739 / 4317 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
|||||||||||
10.04.2016, 16:14 | 8 | ||||||||||
Сообщение было отмечено Surges как решение
Решение
1.
массивы по значению не передаются. 2.
с высокой степенью вероятности, процесс упадет от нехватки памяти. лекарство: http://rextester.com/ZIVJH23566
1
|
116 / 106 / 51
Регистрация: 29.03.2016
Сообщений: 480
|
||||||||||||||||||||||||||||||||||||||||||||||
10.04.2016, 16:14 | 9 | |||||||||||||||||||||||||||||||||||||||||||||
Это можно сделать несколькими способами: 1. Использовать шаблоны. В таком случае заголовок функции будет выглядеть как
1) Вариант 1 (статическое распределение памяти):
Достоинством первого метода является то, что компилятор сам определяет размеры массива (снижается число потенциальных ошибок). Принципиальное достоинство второго метода - возможность работы с матрицами неуказанного при компиляции размера. Третий метод обладает обоими достоинствами (безопасность и динамические размеры), но требует знания STL. PS Первый и второй методы можно объединить:
1
|
132 / 158 / 87
Регистрация: 06.04.2016
Сообщений: 992
|
||||||
10.04.2016, 16:18 | 10 | |||||
Какая у Вас версия того в чем Вы пишете? И вообще в чем Вы пишете?
Предполагаю, что нельзя писать две переменные типа в угловых скобках в шаблоне:
0
|
116 / 106 / 51
Регистрация: 29.03.2016
Сообщений: 480
|
|
10.04.2016, 16:20 | 11 |
DemolitionMan, можно
0
|
132 / 158 / 87
Регистрация: 06.04.2016
Сообщений: 992
|
|
10.04.2016, 16:23 | 12 |
Скажите, пожалуйста, Surges, в чем было дело?
0
|
8739 / 4317 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
|
||||||
10.04.2016, 16:26 | 13 | |||||
Surges,
так же, сам по себе алгоритм сортировки у вас работает не верно. иногда случается вылет за пределы диапазона массива: http://rextester.com/TXHF8438
1
|
10.04.2016, 16:26 | |
10.04.2016, 16:26 | |
Помогаю со студенческими работами здесь
13
Почему компилятор ругается? Почему ругается компилятор? Почему компилятор ругается? Использование класса QSignalMapper + компилятор ругается на указатель this Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |