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

Подсчитать общее число элементов в стеках

24.05.2015, 20:50. Показов 1453. Ответов 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
25
26
27
28
29
30
31
32
33
34
35
36
37
#include <iostream>
 using namespace std;
 
    struct Node
    {
        char character;
        Node *next;
    };
 
    Node*Head;
 
    void push(Node*Head, char character)
   {
    Node *new_elem = new Node;
 
        if (Head== 0)
        {
            Head= new_elem;
        }
        else new_elem->next =Head;
             Head= new_elem;
    }
 
    bool pop(Node*&Head, char &character)
    {
        if (Head== 0)
        return false;
 
        Node*del_elem =Head;
 
        character = Head->character;
        Head= Head->next;
 
        delete del_elem;
 
        return true;
    }
Добавлено через 1 час 23 минуты
Хотя бы как в одном стеке найти количество элементов напишите, ну пожаааааааааааалуйста.

Добавлено через 2 часа 31 минуту
уже лучше,но все равно не то
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
#include<iostream>
using namespace std;
 
struct Stack
{ 
int info; 
Stack*Next; 
};
 
Stack*Head;
int Razmer(Stack* Head);
 
void Push_Stack(Stack*&Head,int DataItem)
{
    Stack*List= new Stack;
    List->info=DataItem;
    if (Head==NULL)
    { 
        Head==List;
    }
    else
    {
        List->Next=Head;
        Head=List;
    }
}
 
void Make_Stack(int n, Stack*&Head){
  if (n > 0) {
    int tmp;//вспомогательная переменная
    cout << "Введите значение ";
    cin >> tmp; //вводим значение информационного поля
    Push_Stack(tmp, Head);
    Make_Stack(n-1, Head);
  }
}
 
int Razmer(Stack* Head)
{
if(!Head) return 0;
int count = 0;
 
while(Head!=0)
{
count++;
Head = Head->Next;
}
cout << "\n";
 
return count;
}
 
void main()
{
setlocale(LC_ALL, "Russian");
cout<<"Введите кол-во эл-в в списке\n";
int n;
cin>>n;
Stack *Head; 
Make_Stack( n, *&Head);
cout << "\n Razmer = " <<Razmer(Head);
system("pause");
}
Добавлено через 1 час 1 минуту
кто-нибудь, ну пожааааааааааалуйста. о великий человек-программист найдись
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.05.2015, 20:50
Ответы с готовыми решениями:

Даны два стека. Используя операции Push_Stack, Pop_Stack и функцию Is_Empty_Stack подсчитать общее число элементов в стеках
Кто может решить эту задачу? (Желательно с комментариями, чтобы хотя бы разобраться потом.) Даны два стека. Используя операции...

Подсчитать общее число неотрицательных элементов в массиве
Задан двумерный массив А из 8-и строк и 3-х столбцов. Составить программу, которая подсчитывает общее число неотрицательных элементов в...

TBasic. Подсчитать общее число нулевых элементов
Даны одномерные массивы А(Р) и В(К) P&lt;=8,K&lt;=20.Подсчитать общее число нулевых элементов.Спасибо!

1
0 / 0 / 1
Регистрация: 24.11.2014
Сообщений: 16
31.05.2015, 21:13  [ТС]
проблемы с make. может-быть можно как-нибудь без нее???
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
#include<iostream>
using namespace std;
 
struct Stack
{ 
int info; 
Stack*Next; 
};
 
Stack*Head;
int Razmer(Stack* Head);
 
void Push_Stack(Stack*&Head,int DataItem)
{
    Stack*List= new Stack;
    List->info=DataItem;
    if (Head==NULL)
    { 
        Head==List;
    }
    else
    {
        List->Next=Head;
        Head=List;
    }
}
 
void Make_Stack(int n, Stack*&Head){
  if (n > 0) {
    int tmp;//вспомогательная переменная
    cout << "Введите значение ";
    cin >> tmp; //вводим значение информационного поля
    Push_Stack(tmp, Head);
    Make_Stack(n-1, Head);
  }
}
 
int Razmer(Stack* Head)
{
if(!Head) return 0;
int count = 0;
 
while(Head!=0)
{
count++;
Head = Head->Next;
}
cout << "\n";
 
return count;
}
 
void main()
{
setlocale(LC_ALL, "Russian");
cout<<"Введите кол-во элементов в стеке\n";
int n;
cin>>n;
Stack *Head; 
Make_Stack( n, *&Head);
cout << "\n Razmer = " <<Razmer(Head);
system("pause");
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.05.2015, 21:13
Помогаю со студенческими работами здесь

Подсчитать общее число неотрицательных элементов в массиве
Задан двумерный массив А из 8-и строк и 3-х столбцов. Составить программу, которая подсчитывает общее число неотрицательных элементов в...

Подсчитать общее число делителей
Определить победителя. Два школьника записывают по одному натуральному числу подсчитать общее число делителей, победит тот школьник, у...

Подсчитать общее число вложенных символов
Дана строка символов. Подсчитать общее число вложенных символов +,*,- в строку

DataGridView - подсчитать общее число строк
Здравствуйте! Помогите разобраться, как написать код, сохраняющий общее количество строк, находящихся в гриде. Идея такова, что...

Подсчитать общее число вхождений символов '+', '–', '*' в последовательность
Дана последовательность из n символов. Подсчитать общее число вхождений символов '+', '–', '*' в данную последовательность. Надеюсь на...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru