Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 02.10.2014
Сообщений: 5

Шаблон функции, использующий поля структуры

09.01.2015, 22:10. Показов 1052. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В очередной раз у меня возникают проблемы с доступом к полям структуры, и на этот раз уже в функции. У меня есть две (ну, на самом деле больше, но сути это не меняет) функции быстрой сортировки:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
void quickSort_year(int left, int right) 
{
    int i = left, j = right;
    Video tmp;
    int pivot = salon[(left + right) / 2].year;
    while (i <= j) 
    {
        while (salon[i].year < pivot) i++;
        while (salon[j].year > pivot) j--;
        if (i <= j)
        {
            tmp = salon[i];
            salon[i] = salon[j];
            salon[j] = tmp;
            i++;
            j--;
        }
    };
    if (left < j)
    quickSort_year(left, j);
    if (i < right)
    quickSort_year(i, right);
}
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
void quickSort_numb(int left, int right) 
{
    int i = left, j = right;
    Video tmp;
    int pivot = salon[(left + right) / 2].numb;
    while (i <= j) 
    {
        while (salon[i].numb < pivot) i++;
        while (salon[j].numb > pivot) j--;
        if (i <= j)
        {
            tmp = salon[i];
            salon[i] = salon[j];
            salon[j] = tmp;
            i++;
            j--;
        }
    };
    if (left < j)
    quickSort_numb(left, j);
    if (i < right)
    quickSort_numb(i, right);
}
Массив структур salon - глобальный, если что.
Функции за исключением названий и используемого поля практически идентичны, но я не знаю, как сделать из этого шаблон или хотя бы функцию, которая принимала бы структуру и поле, по которому пошла бы сортировка. Гугл мне не помог, а перечитывать учебник по шаблонам, в которых я мало что понимаю, времени уже маловато. Есть ли способ сократить количество кода до одной универсальной функции, или для сортировки по каждому отдельному полю придется делать ещё одну новую функцию, почти идентичную остальным?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.01.2015, 22:10
Ответы с готовыми решениями:

error C2448: factor: вероятно, инициализатор, использующий стиль функции, является определением функции
#include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;math.h&gt; using namespace std; int main(){// описание и инициализация заданной...

Структура (значение поля структуры приравнять к значению функции)
Можно ли значение поля структуры приравнять к значению функции вот так STUD1.SES=COR(); Делаю так не присваивается пишет 0

Шаблон структуры
можно ли в с++ создать шаблон структуры? Не класса, именно структуры. Т.е. есть у меня struct A { float e; float e1; }; ...

1
 Аватар для casper007
71 / 71 / 58
Регистрация: 12.12.2013
Сообщений: 420
09.01.2015, 22:38
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
void quickSort_numb(int left, int right, int FlagSort) 
{
    int i = left, j = right;
    Video tmp;
if(FlagSort==0) { int pivot = salon[(left + right) / 2].year;}
else                  {int pivot = salon[(left + right) / 2].numb}
    while (i <= j) 
    {
       if(FlagSort==0) 
         {
           while (salon[i].numb < pivot) i++;
           while (salon[j].numb > pivot) j--;
           }
        else 
          {
            while (salon[i].year < pivot) i++;
            while (salon[j].year > pivot) j--;
          }
        if (i <= j)
        {
            tmp = salon[i];
            salon[i] = salon[j];
            salon[j] = tmp;
            i++;
            j--;
        }
    };
    if (left < j)
    quickSort_numb(left, j);
    if (i < right)
    quickSort_numb(i, right);
}

Пожалуй, самый примитивный и ленивый вариант.

Добавлено через 1 минуту
Большой минус заключается в проверках при каждом повторении цикла.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.01.2015, 22:38
Помогаю со студенческими работами здесь

Шаблон структуры
Создать шаблон структуры &quot;владелец автомобиля&quot; со следующими полями : фамилия, имя, номер автомобиля, дата постановки на учет(структура -...

Шаблон структуры
Как можно заполнить данную структуру вручную? Приведите пожалуйста простенький пример.. template &lt;class T&gt; struct A { T...

Шаблон структуры данных
Шаблон структуры данных – двухуровневый массив указателей на объекты. Массив верхнего уровня – статический, массивы нижнего уровня –...

Шаблон структуры данных
Задание на курсовую работу: шаблон структуры данных – массив указателей на заголовки списков. Элемент списка содержит указатель на объект....

Шаблон структуры данных
Всем привет, в универе дали задание, не понимаю совсем, напишите пожалуйста, Разработать шаблоны структуры данных в памяти. Тип...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru