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

Рекурсивная функция с переменным числом аргументов на С++98

25.03.2020, 11:25. Показов 715. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день! Столкнулся с проблемой построения иерархического дерева, состоящего из указателей на абстрактные элементы. Хотелось бы обращаться к элементам структуры по перечню индексов в структуре. Могу использовать ТОЛЬКО С++98.
Примерный желаемый код, который не компилируется, прилагаю.

C++ (Qt)
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
33
34
35
36
37
38
39
40
41
#include <iostream>
#include <map>
 
using namespace std;
 
class Iel
{
public:
    virtual void addElement(Iel* _el, int _index, int _other, ...) = 0;
};
 
class el : public Iel
{
public:
    void addElement(Iel* _el, int _index, int _other, ...)
    {
        if (_other == 0)
            m_map[_index] = _el;
        else
        {
            std::map<int, Iel*>::const_iterator it = m_map.find(_index);
            if (it != m_map.end())
                it->second->addElement(_el, _other);
        }
    }
 
private:
    std::map<int, Iel*> m_map;
};
 
int main()
{
    el e1;
    el e2;
    el e3;
    el e4;
 
    e1.addElement(&e2, 2, 0);
    e1.addElement(&e3, 2, 3, 0);
    e1.addElement(&e4, 2, 3, 4, 0);
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.03.2020, 11:25
Ответы с готовыми решениями:

Функция с переменным числом аргументов
Здравствуйте, у меня возникла трудность я пытаюсь сделать функцию с переменным числом аргументов и подаю ей на вход адрес вещественных...

Шаблонная функция с переменным числом аргументов
Сабж. Каким образом можно запретить использование шаблонной функции, если тип одного из аргументов не соответствует требуемому? Есть...

Функция с переменным числом аргументов (через шаблоны)
Доброго времени суток! Встал вопрос с реализацией такой функции. template&lt;typename... Args&gt; returntype functionname(const...

4
Just Do It!
 Аватар для XLAT
4201 / 2657 / 654
Регистрация: 23.09.2014
Сообщений: 8,955
Записей в блоге: 3
25.03.2020, 13:16
Цитата Сообщение от sema_90 Посмотреть сообщение
который не компилируется
Сюда
Цитата Сообщение от sema_90 Посмотреть сообщение
it->second->addElement(_el, _other);
добавьте третий аргумент согласно вашему определению данного метода.

например:
C++
23
it->second->addElement(_el, _other, 1);
0
0 / 0 / 0
Регистрация: 28.01.2012
Сообщений: 46
25.03.2020, 14:27  [ТС]
В этом случае при добавлении e3 к e1 функция передает первым элементом есть 2, поэтому вызывается метод addElement для Iel c ключом 2, и в функцию передается _first = 3, _other = 1, в место _other = 0

Добавлено через 56 минут
Ради удобства конечного использования создал дополнительный объект. Возможно избыточное и костыльное решение, если кто сможет подсказать как сделать более аккуратно на с++98, буду рад.

C++ (Qt)
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#include <iostream>
#include <map>
#include <stdarg.h>
#include <cstring>
 
using namespace std;
 
class Indexes
{
public:
    Indexes(int _keys, ...) : m_pos(0)
    {
        memset(this, 0, sizeof (*this));
        int* p = &_keys;
        int i = 0;
        while (p[i])
        {
            m_keys[i] = p[i];
            i++;
        }
    }
    Indexes(int* _keys) : m_pos(0)
    {
        memset(this, 0, sizeof (*this));
        int i = 0;
        while (_keys[i])
        {
            m_keys[i] = _keys[i];
            i++;
        }
    }
 
    int* getValue()
    {
        int* result = &(m_keys[m_pos++]);
        if (m_keys[m_pos] == 0) m_pos = 0;
        return result;
    }
private:
    int m_keys[10];
    int m_pos;
 
};
 
class Iel
{
public:
    virtual void addElement(Iel* _el, Indexes _index) = 0;
};
 
class el : public Iel
{
public:
    void addElement(Iel* _el, Indexes _index)
    {
        int* ind = _index.getValue();
        if (ind[1] == 0)
            m_map[*ind] = _el;
        else
        {
            std::map<int, Iel*>::const_iterator it = m_map.find(*ind);
            if (it != m_map.end())
                it->second->addElement(_el, _index.getValue());
        }
    }
 
private:
    std::map<int, Iel*> m_map;
};
 
int main()
{
    el e1;
    el e2;
    el e3;
    el e4;
 
    e1.addElement(&e2, Indexes(2, 0));
    e1.addElement(&e3, Indexes(2, 3, 0));
    e1.addElement(&e4, Indexes(2, 3, 4, 0));
 
    int a = 0;
}
0
Just Do It!
 Аватар для XLAT
4201 / 2657 / 654
Регистрация: 23.09.2014
Сообщений: 8,955
Записей в блоге: 3
25.03.2020, 14:49
Цитата Сообщение от sema_90 Посмотреть сообщение
В этом случае
то было на жалобу, что не компилится.

ваша задача выглядит для меня слишком абстрактно, и не хотца додумывать все 100500 вариантов.
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
25.03.2020, 15:07
sema_90,
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
#include <iostream>
#include <map>
#include <cstdarg>
 
void foo(std::map<int, double>& m, size_t count, ...)
{
    std::va_list args;
    va_start(args, count);
    for (size_t i = 0; i < count; ++i)
    {
        int key = va_arg(args, int);
        double val = va_arg(args, double);
        m[key] = val;
    }
    va_end(args);
}
 
int main()
{
    std::map<int, double> m;
    foo(m, 3, 1, 1.111, 2, 2.222, 3, 3.333);
    std::cout
        << m[1] << '\n'
        << m[2] << '\n'
        << m[3] << '\n';
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.03.2020, 15:07
Помогаю со студенческими работами здесь

Шаблоны с переменным числом аргументов
Написал шаблон функции с переменным числом аргументов которая считает сумму своих аргументов. Практики по этому вопросу не имею, поэтому...

Функции с переменным числом аргументов
на пример sum(2,56,515,-23.65,548)?

Функции с переменным числом аргументов
Дело было в дизеле после университета. Хотел написать функцию, в которой заранее не будет известно, сколько будет аргументов, но ничего...

Функции с переменным числом аргументов
Ребята, подскажите пожалуйста, где можно обстоятельно и подробно прочитать про использовании в C++ функций с несколькими аргументами. ...

Функции с переменным числом аргументов
Здравствуйте, изучаю язык программирования D, и вот столкнулся с такой проблемой, что про функции с переменным числом аргументов написано...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru