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

Найти символ который чаще всего встречается

30.05.2018, 17:07. Показов 8697. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано строку А, которая содержит не менее 4-х слов. Необходимо найти символ который чаще всего встречается. Вывести этот символ и слово, где оно наиболее встречалось.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.05.2018, 17:07
Ответы с готовыми решениями:

Найти элемент массива, который чаще всего встречается
3. Найти элемент массива, который чаще всего встречается

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

Массивы строк. Какой символ встречается в этой строке чаще всего?
напишите программу которая принимает с клавы строку и определяет какой символ встречается в этой строке чаще всего. Если таких символов...

6
 Аватар для LegionK
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
30.05.2018, 17:27
Цитата Сообщение от misterfortuna Посмотреть сообщение
Дано строку А, которая содержит не менее 4-х слов
А слова-то чем разделены?
1
0 / 0 / 0
Регистрация: 16.05.2018
Сообщений: 4
30.05.2018, 17:47  [ТС]
Пробелом
0
 Аватар для LegionK
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
30.05.2018, 17:51
Лучший ответ Сообщение было отмечено misterfortuna как решение

Решение

misterfortuna, Все, поздно,придется любым кол-вом знаков препинания . Пробел - тоже символ или его не учитываем?
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
#include <iostream>
 
using std::cout;
using std::string;
using std::endl;
 
int treatment(string & s){            // "Я,,,!!!люблю,,,    ....с++,,," --> "Я люблю Алису"
    string temp(".,:;-_*&@?!");
    int count(0);
    for(int i = 0;i<temp.length();++i){
        while(s.find(temp.at(i)) != s.npos){
            count = s.find(temp.at(i));
            s.erase(count,1);
            s.insert(count," ");
        }
    }
    for(int i = 0;i<s.length()-1;++i){
        if(s.at(i) == ' ' && s.at(i+1) == ' '){
            s.erase(i,1);
            --i;
        }
    }
    if(s.at(s.length()-1) == ' ')s.erase(s.length()-1,1);
    int counter(1);
    for(int i = 0;i<s.length();++i)if(s.at(i) == ' ')++counter;
    return counter;
}
void line_break(string arr[],int size,string &treatmented_str){ // "Я люблю Алису" --> "Я" + "Люблю" + "Алису"
    string temp(treatmented_str);
    if(temp.find(' ') == temp.npos){
        arr[0] = temp;
        return;
    }
    temp.erase(temp.find(' '),temp.length());
    arr[0] = temp;
    int counter(0);
    for(int i = 1;i<size;++i){
        temp = treatmented_str;
        if(size-1 == i){
            temp.erase(0,temp.find_last_of(' ')+1);
            arr[i] = temp;
            break;
        }
        counter = temp.find(' ',counter+1);
        temp.erase(0,temp.find(' ',counter)+1);
        temp.erase(temp.find(' '),temp.length());
        arr[i] = temp;
    }
}
 
int main()
{
    char word('a');
    string main_s,most;
    getline(std::cin,main_s);
 
    int size(treatment(main_s));
    string arr[size];
    line_break(arr,size,main_s);
 
    int counter(0),many(-1);
    for(int i = 0;i<main_s.size();++i){
        counter = 0;
        for(int j = i;j<main_s.length();++j){
            if(main_s.at(i) == main_s.at(j))++counter;
        }
        if(counter > many){
            many = counter;
            word = main_s.at(i);
        }
    }
    cout << word << " : " << many;
    many = -1,counter = 0;
    if(word != ' '){
        for(int i = 0;i<size;++i){
            for(int j = 0;j<arr[i].length();++j){
                if(arr[i].at(j) == word)++counter;
            }
            if(counter > many){
                most = arr[i];
            }
        }
        cout << "\n" << most;
    } else {
        cout << "\n ' ' - is not member of any word";
    }
 
    cout << endl;
    return 0;
}
1
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
30.05.2018, 18:02
Цитата Сообщение от misterfortuna Посмотреть сообщение
Вывести этот символ и слово
То есть вести учёт надо только по буквенным символам? А то ведь может и пробел быть самым частым символом.
0
0 / 0 / 0
Регистрация: 16.05.2018
Сообщений: 4
30.05.2018, 19:36  [ТС]
Верно только буквы
0
 Аватар для LegionK
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
31.05.2018, 04:13
Лучший ответ Сообщение было отмечено misterfortuna как решение

Решение

misterfortuna,если только буквы, то поменяй мейн из первого кода на вот этот :
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
int main()
{
    char word('a');
    string main_s,most;
    getline(std::cin,main_s);
 
    int size(treatment(main_s));
    string arr[size];
    line_break(arr,size,main_s);
 
    int counter(0),many(-1);
    for(int i = 0;i<main_s.size();++i){
        counter = 0;
        for(int j = i;j<main_s.length();++j){
            if(main_s.at(i) == main_s.at(j) && isalpha(main_s.at(i)))++counter;
        }
        if(counter > many){
            many = counter;
            word = main_s.at(i);
        }
    }
    cout << word << " : " << many;
    many = -1,counter = 0;
    for(int i = 0;i<size;++i){
        counter = 0;
        for(int j = 0;j<arr[i].length();++j){
            if(arr[i].at(j) == word)++counter;
        }
        if(counter > many){
            most = arr[i];
            many = counter;
        }
    }
    cout << "\n" << most << " : " << many;
 
    cout << endl;
    return 0;
}
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
31.05.2018, 04:13
Помогаю со студенческими работами здесь

Найти число, которое чаще всего встречается в матрице
как найти число которое больше всего встречается в матрице?

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

Найти элемент массива, который чаще встречается
Найти элемент массива, который чаще встречается.. Допустим: 12122012 Чаще всего встречается: 2

Определить какая согласная чаще всего встречается
введено предложение произвольной длины, определить, какая согласная чаще всего встречается в нем

Определить какое слово в строке встречается чаще всего
ребят,помогите.Для Вас же это как семечки 1. Определить какое слово в строке встречается чаще всего 2. Подсчитать количество букв а...


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

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