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

Обращение к элементам, членам класса

05.03.2018, 13:48. Показов 2067. Ответов 3

Студворк — интернет-сервис помощи студентам
Здравствуйте! Мне нужно выполнить задания из меню (в коде программы), но я не могу понять как обраться в функции к NodeElement *cur и к NodeElement *first. Это нужно для прохождения циклом по массиву. Помогите, пожалуйста!


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
#include <iostream>
#include <string>
#include <ctime>
#include <conio.h>
 
using namespace std;
 
class Stack {
private:
    class NodeElement { // Класс элемента
    public:
        int data;
        NodeElement *next;
    };
    NodeElement *first;
public:
    Stack() {
        first = 0; //Первый равен 0
    }
    ~Stack() {
        makenull();
    }
    void push(int x) {
        NodeElement *temp = new NodeElement; //Добавлние нового элемента
        temp->data = x;
        temp->next = first;
        first = temp;
    }
    int pop() { //Вывод последнего элемента с последующим удалением
        int x = first->data;
        NodeElement *k = first;
        first = first->next;
        delete k;
        return x;
    }
    int top() { //Вывод последнего элемента
        return first->data;
    }
    int empty() { //Проверка на заполненность стека
        if (first == 0) return 1;
        else return 0;
    }
    void makenull() { //Обнуление стека
        while (first != 0) {
            NodeElement *k = first;
            first = first->next;
            delete k;
        }
        first = 0;
    }
    void prtst() {
        NodeElement *cur = first;
        cout << "Элементы стека: ";
        while (cur != NULL) {
            cout << cur->data << "|";
            cur = cur->next;
        }
        cout << endl;
    }
};
 
 
void inputNum(Stack *element, int n) {
    int x=0;
    cout << "Количество элеметов вносимых в стек:" << endl
        << "-> ";
    cin >> n;
    srand(time(0));
    for (int i = 0; i < n; i++) {
        x = 1 + (rand() % +10);
            element->push(x);   
    }
    element->prtst();
    cout << endl;
}
 
void searchEl(Stack *element, int n) { //Функция поиска похожих элеметов стека
    int srh;
    cout << "Введите число для поиска: ";
    cin >> srh;
    /*Здесь курсору нужно присвоить голову*/
    if (/*Здесь должен быть курсор*/ == srh) {
        int 
    }
    element->prtst();
}
 
void printMenu() { //Функция вывода меню
    cout << "1. Поиск элементов в стеке" << endl
        << "2. Удаление элмента стека" << endl
        << "3. Внести число после элемента" << endl
        << "4. Вывод слов начинающихся с заданной буквы" << endl
        << "5. Выход" << endl
        << "   -> ";
}
 
int main() {
    setlocale(LC_ALL, "RUS");
    system("color 00");
    int i, num = 0, n=0;
    Stack *element = new Stack;
    Stack *cur = NULL, *head = NULL;
    cout << "\t\tМеню" << endl;
    do {  //Вызов меню
        printMenu();
        cin >> num;
        inputNum(element, n); //Функция заполнения стека
        switch (num) {
        case 1:
            searchEl(element,n);
            break;
        case 2:
            break;
        case 3:
            break;
        case 4:
            break;
        case 5:
            cout << "Пока!";
            cout << endl;
            break;
        default: cout << "Не верно выбрана цифра!";
        }
    } while (num != 5); //Пока не захотим выйти
    delete element;
    return 0;
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.03.2018, 13:48
Ответы с готовыми решениями:

Оператор this и обращение к членам класса
строка this-&gt;b = new B; означает взять вдресс текущего объекта b и выделить под него память?так? class B{ public: int k; ...

Обращение к элементам класса через []
Пишу класс для работы с комплексными числами, почти все готово, осталось только 1 задание.

Обращение к элементам класса через указатель
Что выполняет в данном случае оператор -&gt; this-&gt;t1 = (gcnew System::Windows::Forms::TextBox()); ? Почему нельзя писать так this.t1...

3
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
05.03.2018, 14:12
Лучший ответ Сообщение было отмечено CyberGlitch как решение

Решение

Сделай функции членами класса.
0
0 / 0 / 0
Регистрация: 20.11.2017
Сообщений: 38
05.03.2018, 14:14  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
Сделай функции членами класса.
void Stack::searchEl(){
{

Так?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
05.03.2018, 14:33
Да.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.03.2018, 14:33
Помогаю со студенческими работами здесь

Доступ к членам класса класса
Всем привет. Вобщем есть базовый класс, и два производных. Пользователь вводит координаты нужно проверить факт пересечения одной фигуры с...

Доступ к членам класса
Есть два класса: #include &quot;stdafx.h&quot; #include &lt;iostream&gt; using namespace std; class CPerson { /*закрытые члены*/ private:...

Доступ к членам класса
Объект класса не может получить доступ к своим переменным?

Доступ к private членам класса
Почему при таком объявлении не работает оператор вывода, по идее он же объявлен как друг класса и должен иметь доступ к членам этого...

Доступ к защищенным членам класса
Срочно!! помогите пожалуйста Что не правильно : class my { int i; public: ………. }; int main() {


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru