
СРОЧНО!!!ПОЖАЛУЙСТА!!!НА С++!!! Самая частая буква Дана строка, возможно, содержащая пробелы.
Определите, какая буква латинского алфавита (или какие буквы) в этой строке встречается чаще всего. При решении этой задачи заглавные и строчные буквы считаются одинаковыми, а прочие символы, не являющиеся буквами, не учитываются. При решении этой задачи нельзя пользоваться вложенными циклами. Входная строка должна обрабатываться за один проход. Входные данные Дана непустая строка. Выходные данные Программа должна вывести в первой строке все буквы, которые встречаются чаще всего в исходной строке. Выводить буквы необходимо в заглавном написании, в алфавитном порядке, без пробелов. Во второй строке выведите единственное число — сколько раз в данной строке встречаются эти буквы. Примеры Ввод Вывод - We all live in the Yellow Submarine! EL 5

Ответы на вопрос

Ответ:
#include <iostream>
#include <cctype>
using namespace std ;
int main() {
string s;
int freqs[26] = { 0 };
getline( cin, s );
for (auto c : s) {
if (isalpha(c)) {
freqs[toupper(c) - 'A'] += 1;
}
}
int max = 0;
string out = "";
for (int i = 0; i < 26; i++) {
if (freqs[i] == max) {
out.push_back((char)'A' + i);
} else if (freqs[i] > max) {
out = "";
out.push_back((char)'A' + i);
max = freqs[i];
}
}
cout << out << endl;
cout << max;
return 0;
}
Объяснение:
удачки с сириусом мужик)



Для решения этой задачи на C++ без использования вложенных циклов, вы можете воспользоваться хеш-мапой для подсчета частоты встречающихся букв. Вот пример реализации:
cpp#include <iostream>
#include <string>
#include <unordered_map>
#include <cctype>
int main() {
std::string input;
std::getline(std::cin, input);
std::unordered_map<char, int> letterFrequency;
for (char c : input) {
if (std::isalpha(c)) {
// Преобразуем символ в верхний регистр для учета заглавных и строчных букв
c = std::toupper(c);
letterFrequency[c]++;
}
}
int maxFrequency = 0;
for (const auto& pair : letterFrequency) {
maxFrequency = std::max(maxFrequency, pair.second);
}
std::string mostFrequentLetters;
for (const auto& pair : letterFrequency) {
if (pair.second == maxFrequency) {
mostFrequentLetters.push_back(pair.first);
}
}
// Сортируем буквы в алфавитном порядке
std::sort(mostFrequentLetters.begin(), mostFrequentLetters.end());
std::cout << mostFrequentLetters << std::endl;
std::cout << maxFrequency << std::endl;
return 0;
}
Этот код сначала создает хеш-мапу letterFrequency
, чтобы подсчитать частоту букв во входной строке, игнорируя регистр и не-буквенные символы. Затем он находит максимальную частоту и собирает буквы с этой максимальной частотой в строку mostFrequentLetters
, сортируя их в алфавитном порядке. Наконец, выводит результат.


Похожие вопросы
Топ вопросов за вчера в категории Информатика







Последние заданные вопросы в категории Информатика
-
Математика
-
Литература
-
Алгебра
-
Русский язык
-
Геометрия
-
Английский язык
-
Химия
-
Физика
-
Биология
-
Другие предметы
-
История
-
Обществознание
-
Окружающий мир
-
География
-
Українська мова
-
Информатика
-
Українська література
-
Қазақ тiлi
-
Экономика
-
Музыка
-
Право
-
Беларуская мова
-
Французский язык
-
Немецкий язык
-
МХК
-
ОБЖ
-
Психология
-
Физкультура и спорт
-
Астрономия
-
Кыргыз тили
-
Оʻzbek tili