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

Написать функцию, которая определяет, сколько раз в стеке встречается заданный символ

28.04.2014, 14:28. Показов 2862. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать функцию, которая определяет, сколько раз в стеке встречается заданный символ (СИМВОЛ ЗАДАЕТСЯ С КЛАВИАТУРЫ)
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.04.2014, 14:28
Ответы с готовыми решениями:

Написать функцию, которая будет считать сколько раз заданный элемент встречается в списке
Должны использоватся два параметра, список и элемент заранее спасибо за ответ)

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

Написать программу, которая определяет сколько раз встречается в тексте слово, заданное пользователем
Здравствуйте, подскажите как сделать чтобы слово считывалось из текстового файла (который будет заранее создан), а не из предложения,...

2
 Аватар для DiffEreD
1458 / 795 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
28.04.2014, 14:43
Лучший ответ Сообщение было отмечено Pavel_2011 как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <stack>
 
template <typename T>
size_t count(std::stack<T> st, const T& value) {
   size_t result = 0;
   while (!st.empty())
      st.top() == value ? ++result, st.pop() : st.pop();
   return result;
}
 
int main()
{
   std::stack<char> stack{std::stack<char>::container_type{'a', 'b', 'c', 'd', 'e', 'b', 'a', 'b'}};
   while (true) {
      std::cout << "Enter letter: -> ";
      char ch;
      std::cin >> ch;
      std::cout << count(stack, ch) << "\n";
   }
 
   return 0;
}
0
1 / 1 / 1
Регистрация: 23.10.2013
Сообщений: 69
28.04.2014, 14:53  [ТС]
Можно более простым способом?

Добавлено через 2 минуты
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
#include <iostream>
#include <string.h>
using namespace std;
 
struct node {
char info;
node *next;//поле для связи с другим узлом
};
 
node* first(char ch)//начальное формировнаие стека 
{
node* p=new node;//выделение динамической памяти под новый узел
p->next=NULL;//перед первым нет предыдущего узла - на NULL
p->info=ch;
return p;
}
 
void push(node** top, char ch)//добавление элемента в стек
{
node* p=new node;//выделение динамической памяти под новый узел
p->info=ch;
p->next=*top;//связь с предыдущим узлом (вершиной стека)
*top=p;//вершину стека перемещаем на созданный узел
}
 
void clean(node** top)// очитска стека
{
node *temp;
while (*top!=NULL)//пока не досигли конец файла
{
temp=(*top)->next;//устанавливаем указатель temp на след. элемент
delete *top;
*top=temp;//переводим указатель вершины на след. элемент
}
}
 
void print(node* top)//распечатка стека
{
    while (top!=NULL)//пока не достигли конец стека
    {
        cout<<top->info<<endl;
        top=top->next;//перемещаемся к след.узлу
    }
}
bool sogl(char ch){
    char s[]="qwrtypsdfghjklzxcvbnmQWRTYPSDFGHJKLZXCVBNM";
    if (strchr(s,ch)) return true;
    else return false;
}
 
void delnode(node ** top) // удаление узлов с заданным значением d
 { 
  node *temp, *prev;
  temp= *top;//устанавливаем вспомогательный указатель temp на вершину
  prev=*top; // предыдущий узел для текущего 
  while (temp!=NULL)   
  {
    if (sogl(temp->info)) // если нашли узел с заданным значением
    {
      if  (temp==(*top)) // если это вершина стека
       {
         (*top)=temp->next;
         delete temp;
         temp=*top;   }
      else  // если найденный узел не является вершиной
       {
         prev->next=temp->next;
         delete temp;
         temp=prev->next;
       }
    }
   else // если узел не содержал заданного значения
    {
     prev=temp;
     temp=temp->next;
     }
  }
}
 
 
 
 
 
void main(){
setlocale (0,"");
node* top=NULL;
char ch,cn;
cout<<"Введите символ"<<endl;
cin>>ch;
top=first(ch);
do {
cout<<"Введите символ"<<endl;
cin>>ch;
push(&top, ch);
cout<<"Продолжить? (y/n)"<<endl;
cin>>ch;
}while(ch!='n');
cout<<"Стек: "<<endl;
print(top);
delnode(&top);
cout<<"New: "<<endl;
print(top);
cout<<"New: "<<endl;
print(top);
clean(&top);
if (top==NULL) cout<<"Стек очищен";
system ("pause");
}
Добавлено через 37 секунд
это моя программа, но только без этой функции
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.04.2014, 14:53
Помогаю со студенческими работами здесь

Написать подпрограмму, которая подсчитывает, сколько раз в строке встречается определенный символ
Задание. Написать подпрограмму, которая подсчитывает, сколько раз в строке встречается определенный символ. В строке символов определить,...

Написать программу,которая подсчитывает сколько раз заданный символ входит в данную строку текста
Дан текст.Написать программу,которая подсчитывает сколько раз заданный символ входит в данную строку текста.

Определить, сколько раз встречается заданный символ
Определить, сколько раз встречается заданный символ во фразе “Сделал дело – гуляй смело”.

Сколько раз встречается заданный символ в строке
Создайте кнопку и два текстовых поля. Кнопка должна подсчитывать сколько раз встречается заданный символ (введенный в первое текстовое...

Сколько раз заданный символ встречается в строке
Помогите написать подпрограмму, которая подсчитывает, сколько раз заданный символ встречается в строке...Никак не получается.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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