С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
Alvin Seville
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 9
1

Оператор += работает, но только в форме вызова ->operator+=(.)

24.02.2019, 14:53. Показов 1114. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Кликните здесь для просмотра всего текста
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
#include <iostream>
#include <stdexcept>
#include <vector>
#include <assert.h>
 
using namespace std;
 
// Óçåë îäíîñâÿçíîãî ñïèñêà.
template<typename T>
class node
{
private:
    T value;
    node<T>* next;
    
    void init(T value, node<T>* next)
    {
        this->value = value;
        this->next = next;
    }
    
public:
    // Âîçâðàùàåò çíà÷åíèå value.
    T get_value() const
    {
        return value;
    }
    
    // Óñòàíàâëèâàåò çíà÷åíèå value.
    void set_value(T value)
    {
        this->value = value;
    }
    
    // Âîçâðàùàåò çíà÷åíèå next.
    node<T>* get_next() const
    {
        return next;
    }
    
    // Óñòàíàâëèâàåò çíà÷åíèå next.
    void set_next(node<T>* value)
    {
        next = value;
    }
    
    node(T value, node<T>* next = NULL)
    {
        init(value, next);
    }
    
    node(const node<T>& target)
    {
        init(target.get_value(), target.get_next());
    }
    
    ~node()
    {
    }
    
    // Âûâîäèò ñòðîêîâîå ïðåäñòàâëåíèå îáúåêòà.
    void print() const
    {
        cout << value;
    }
    
    // Âûâîäèò ñòðîêîâîå ïðåäñòàâëåíèå îáúåêòà è ïåðåõîäèò íà íîâóþ ñòðîêó.
    void println() const
    {
        println();
        cout << endl;
    }
};
 
// Ñòåê.
template<typename T>
class stack
{
private:
    node<T>* head;
    int count;
    
    void init()
    {
        head = NULL;
        count = 0;
    }
    
    void throw_if_empty(int count)
    {
        assert(count >= 0);
    }
    
public:
    // Âîçâðàùàåò çíà÷åíèå count.
    int get_count() const
    {
        return count;
    }
    
    stack()
    {
        init();
    }
    
    stack(int count, T* sequence)
    {
        assert(count >= 0);
        assert(sequence != NULL);
        init();
        T* current = sequence;
        for (int i = 0; i < count; i++)
        {
            push(*current);
            current++;
        }
    }
    
    stack(const vector<T>& vector)
    {
        init();
        vector(vector != NULL);
        for (int i = 0; i < vector->size(); i++)
            push(vector[i]);
    }
    
    ~stack()
    {
        clear();
    }
    
    // Âñòàâëÿåò ýëåìåíò â ñòåê.
    void push(T item)
    {
        head = new node<T>(item, head);
        count++;
    }
    
    // Óäàëÿåò è âîçâðàùàåò óäàë¸ííûé ýëåìåíò èç ñòåêà.
    T pop()
    {
        throw_if_empty();
        node<T>* to_remove = head;
        T result_item = head->get_value();
        head = head->get_next();
        delete to_remove;
        count--;
        return result_item;
    }
    
    // Âîçâðàùàåò ýëåìåíò íà âåðøèíå ñòåêà.
    T peek() const
    {
        throw_if_empty();
        return head->get_value();
    }
    
    // Î÷èùàåò ñòåê.
    void clear()
    {
        node<T>* current = head;
        while (current)
        {
            node<T>* to_remove = current;
            current = current->get_next();
            delete to_remove;
        }
        init();
    }
    
    // Âûâîäèò ñòðîêîâîå ïðåäñòàâëåíèå îáúåêòà.
    void print() const
    {
        node<T>* current = head;
        cout << "[";
        while (current)
        {
            current->print();
            if (current->get_next())
                cout << ", ";
            current = current->get_next();
        }
        cout << "]";
    }
    
    // Âûâîäèò ñòðîêîâîå ïðåäñòàâëåíèå îáúåêòà è ïåðåõîäèò íà íîâóþ ñòðîêó.
    void println() const
    {
        print();
        cout << endl;
    }
    
    void operator +=(const T& item)
    {
        push(item);
    }
};
 
int main(int argc, char** argv)
{
    stack<int>* s = new stack<int>();
    for (int i = 0; i < 10; i++)
        s->operator+=(i);
    s->println();
    delete s;
    return 0;
}

Выше весь код. Что интересует. Следующий оператор работает только так:
C++
1
s->operator+=(i);
, вот так:
C++
1
s += i;
уже нет. Использую Dev C++ 5.11.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.02.2019, 14:53
Ответы с готовыми решениями:

Qt не работает микрофон во второй форме после её вызова
Здравствуйте, Форумчане! Столкнулся со следующей проблемой. Вызываю одну вторую форму из первой...

Вызова operator в main
Помогите разобраться с этой ошибкой - Пишет что нарушена семантика. Invalid operands to binary...

Исправить код: работает только оператор сложения
Как надо исправить код, чтобы можно было выбирать сначала действия с числами и вводить эти числа...

Код работает только на первой форме
procedure TForm1.FormShow(Sender: TObject); var f : TextFile; s : String; x:integer; begin...

1
19409 / 10028 / 2443
Регистрация: 30.01.2014
Сообщений: 17,678
24.02.2019, 15:14 2
Лучший ответ Сообщение было отмечено Соколиный глаз как решение

Решение

Цитата Сообщение от Соколиный глаз Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
int main(int argc, char** argv)
{
    stack<int>* s = new stack<int>();
    for (int i = 0; i < 10; i++)
        s->operator+=(i);
    s->println();
    delete s;
    return 0;
}
C++
1
2
3
4
5
6
7
8
int main(int argc, char** argv)
{
    stack<int> s;
    for (int i = 0; i < 10; i++)
        s += i;
    s.println();
    return 0;
}
Добавлено через 49 секунд
Соколиный глаз, для использования new в С++ должны быть причины. Вы же его используете просто потому, что так было в C# - это категорически неправильно.
1
24.02.2019, 15:14
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.02.2019, 15:14
Помогаю со студенческими работами здесь

KeyPressEventHandler Работает только на пустой форме
Уважаемые форумчане, добрый вечер! Помогите разобраться с проблемой. Решил я добавить...

Stringgrid работает только на главной форме
уважаемые форумчане помогите мне с моей проблемой, у меня не работает таблица stringgrid в...

В одной форме много datepicker, но работает только первый
&lt;p&gt;DOH:&lt;br/&gt; &lt;input name=&quot;doh&quot; type=&quot;text&quot; id=&quot;datepicker&quot; /&gt; ...

operator это оператор или операция?
Как правильно переводится слово operator: операция или оператор?

Происхождение и сущность ошибок.оператор operator++
Пожалуста, обьясните про оператор operator++. честно написать, я вобще почти ничего не понял. Как...

Оператор интервала ( range operator ). Ну почему он так?
Речь пойдёт об операторе &quot;..&quot; и его второй разновидности &quot;...&quot;. Все вы, конечно, знаете, что у...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
Полезные поделки на Arduino, которые можно сделать самому
raxper 06.01.2025
Arduino как платформа для творчества Arduino представляет собой удивительную платформу для технического творчества, которая открывает безграничные возможности для создания уникальных проектов. Эта. . .
Подборка решений задач на Python
IT_Exp 06.01.2025
Целью данной подборки является предоставление возможности ознакомиться с различными задачами и их решениями на Python, что может быть полезно как для начинающих, так и для опытных программистов. . . .
С чего начать программировать микроконтроллер­­ы
raxper 06.01.2025
Введение в мир микроконтроллеров Микроконтроллеры стали неотъемлемой частью современного мира, окружая нас повсюду: от простых бытовых приборов до сложных промышленных систем. Эти маленькие. . .
Из чего собрать игровой компьютер
inter-admin 06.01.2025
Сборка игрового компьютера требует особого внимания к выбору комплектующих и их совместимости. Правильно собранный игровой ПК не только обеспечивает комфортный геймплей в современных играх, но и. . .
Обновление сайта www.historian.b­y
Reglage 05.01.2025
Обещал подвести итоги 2024 года для сайта. Однако начну с того, что изменилось за неделю. Добавил краткий урок по последовательности действий при анализе вредоносных файлов и значительно улучшил урок. . .
Как использовать GraphQL в C# с HotChocolate
Programming 05.01.2025
GraphQL — это современный подход к разработке API, который позволяет клиентам запрашивать только те данные, которые им необходимы. Это делает взаимодействие с API более гибким и эффективным по. . .
Модель полного двоичного сумматора с помощью логических операций (python)
AlexSky-coder 04.01.2025
def binSum(x:list, y:list): s=^y] p=x and y for i in range(1,len(x)): s. append((x^y)^p) p=(x and y)or(p and (x or y)) return s x=list() y=list()
Это мы не проходили, это нам не задавали...(аси­­­­­­­­­­­­­­­­­­­­­­­­­­х­р­о­н­­н­­­ы­­й счётчик с управляющим сигналом зад
Hrethgir 04.01.2025
Асинхронный счётчик на сумматорах (шестиразрядный по числу диодов на плате, но наверное разрядов будет больше - восемь или шестнадцать, а диоды на старшие), так как триггеры прошли тестирование и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru