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

Иерархические именованные списки

09.08.2019, 00:48. Показов 1045. Ответов 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
24
class Section
{
    private:
    std::string _name;
    std::vector<Book> _books;
    std::vector<Section> _sections;
 
    public:
    Section(std::string name, std::vector<Book> books = std::vector<Book>(0), std::vector<Section> sections = std::vector<Section>(0))
    {
        if (name.empty()) throw "The name cannot be empty";
        else {
            _name = name;
            _books = books;
            _sections = sections;
        }
    }
    std::string get_name() { return _name; }
    std::vector<Book> get_books() { return _books; }
    std::vector<Section> get_sections() { return _sections; }
    void add_book(std::string name, unsigned int total_pages) { _books.push_back(Book(name, total_pages)); }
    void add_book(Book book) { _books.push_back(book); }
    //void add_section(std::string name) { _sections.push_back(Section(name)); }
};
0

Помощь в написании контрольных, курсовых и дипломных работ здесь.

Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
09.08.2019, 00:48
Ответы с готовыми решениями:

Форма аксесс 2010. иерархические списки
Здравствуйте! Форма «АКТЫ»: Строка «инспектор» – сортировка по именам. Строка «наимоб» –...

Именованные и не именованные константы
Доброй ночи. Скажите пожалуйста чем отличаются именованные и неименованные константы. Я прогуглил...

Иерархические URL
Здравствуйте Разрабатываю свою CMS и возник такой вопрос. иерархия страниц сайта будет...

Иерархические заголовки продолжение
Проект прикрепил(версия QT 5.7.0), пере собрал скинутый класс для себя ничего не меняю в логике и...

1
Эксперт С++
8430 / 4102 / 895
Регистрация: 15.11.2014
Сообщений: 9,216
09.08.2019, 01:11 2
Лучший ответ Сообщение было отмечено DontRobot как решение

Решение

Цитата Сообщение от DontRobot Посмотреть сообщение
сделать иерархический именованный список
https://rextester.com/SXQ18377

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
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
#include <iostream>
#include <cassert>
#include <string>
#include <vector>
 
struct block
{
    static block make(const std::string& name)
    {
        return block(name);
    }
 
    block(const std::string& name)
        : m_name(name)
        , m_parent()
        , m_children()
    {}
    
    block(const std::string& name, block& parent)
        : m_name(name)
        , m_parent(&parent)
        , m_children()
    {}
    
    block(const block& rhs)
        : m_name(rhs.m_name)
        , m_parent(rhs.m_parent)
        , m_children(rhs.m_children)
    {}
        
    block& operator = (const block& rhs) 
    { 
        if(this != &rhs)
        {
            this->m_name     = rhs.m_name;
            this->m_parent   = rhs.m_parent;
            this->m_children = rhs.m_children;
        }
        return *this; 
    }
 
    block& add(const std::string& name)
    {
        this->m_children.emplace_back(name, *this);
        return this->m_children.back();
    }
    
    block& done()
    {
        assert(this->m_parent);
        return *this->m_parent;
    }
    
    const block& view(const size_t deep = 0) const
    {
        std::cout << std::string(deep * 2, ' ') << this->m_name << '\n';
        for(const auto& el: this->m_children)
            el.view(deep + 1);
        return *this;
    }
private:
    std::string  m_name;    
    block*       m_parent;
    std::vector<block> 
        m_children;
};
 
int main()
{
    const auto example = block::make("root")
    .add("one")
        .add("ololo").done()
        .add("trololo").done()        
    .done()
    .add("two")
        .add("hello").done()
        .add("world").done()        
    .done()
    .view();
}
Код
root
  one
    ololo
    trololo
  two
    hello
    world
2
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
09.08.2019, 01:11

Иерархические рекурсивные запросы
Ищу сумму дочерних строк каждой каждой корневой строки , получается это сделать только с помощью ...

Иерархические (рекурсивные) запросы
Здравствуйте, читаю про Иерархические запросы здесь и вроде бы все хорошо, но на connect_by_path я...

Динамические-иерархические таблицы
Добрый день! Так случилось, что опять надо работать с Office :) В общем суть такая: нужно...

Иерархические справочники (таблицы) в Access
Возможно ли их создание? к примеру чтоб таблица &quot;товары&quot; имела разделение на группы по типу...


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

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

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