Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 20, средняя оценка - 4.70
dolmatova22
17 / 0 / 1
Регистрация: 13.03.2010
Сообщений: 30
#1

Найти частоту появления букв в строке - C++

25.04.2010, 22:44. Просмотров 3333. Ответов 6
Метки нет (Все метки)

Найти частоту появления букв в строке. Определить наиболее часто встречаемую букву.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.04.2010, 22:44
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Найти частоту появления букв в строке (C++):

Найти частоту появления согласных букв в строке - C++
Найти частоту появления согласных букв в строке.можно в с++ или си.

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

Построить столбиковую гистограмму, отражающую частоту появления букв заданного алфавита - C++
УСЛОВИЕ : Дана строка, содержащая некоторый текст (включая пробелы и знаки препинания). Под словом понимается набор символов, не содержащий...

Найти частоту букв и частоту слов в предложении - C++
Друзья! Нужна помощь. нужно найти частоту каждого слова и частоту каждой буквы. Т.е. пишем предложение, допустим, "Добро пожаловать на...

Найти частоту появления символов в исходном текстовом файле - C++
Здравствуйте, возникли такие проблемы. Пишу на Visual C++ 2010. На первом этапе вывода текста из файла не получается его забить...

Массивы. Найти частоту появления каждого из m элементов, наиболее часто встречающиеся (m << n) в процентах - C++
помогите пожалуйста с заданием на DEV C++ В целочисленном массиве K (n) многие элементы, которые повторяются. Найти частоту появления...

6
M128K145
Эксперт JavaЭксперт С++
8320 / 3540 / 143
Регистрация: 03.07.2009
Сообщений: 10,708
25.04.2010, 23:02 #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
#include <iostream>
int main()
{
    int mas[256];
    int i = 0, len, imax = 0;
    while(i < 256) 
        mas[i++] = 0;
    char str[300];
    std::cout<<"input string:\n";
    std::cin.getline(str, 300);
    len = strlen(str);
 
    i ^= i;
    while(i < len)
        ++mas[(int)str[i++]];
    
    i ^= i;
    while(i++ < 255)
        if(mas[i] > mas[imax])
            imax = i;
    std::cout<<"symb = "<<(char)imax;
    system("pause");
    return 0;
}
1
dolmatova22
17 / 0 / 1
Регистрация: 13.03.2010
Сообщений: 30
25.04.2010, 23:03  [ТС] #3
Можно на СИ ?
0
delfamur
42 / 24 / 0
Регистрация: 16.03.2010
Сообщений: 199
25.04.2010, 23:04 #4
хм...тут даже алгоритм большой. создаешь массив чар всех букв обоих регистров. то, что вводим с клавы тоже в чар. начинаем цикл, внутри условие на равенство элемента массива и элемента введеной строки. если равно - (тут тоже удобнее использовать массив, но уже инт) мас[индекс_буквы]++; вот тебе и частота. а потом уже максимальный элемент массива инт и по его индексу вывести букву массива чар
0
M128K145
Эксперт JavaЭксперт С++
8320 / 3540 / 143
Регистрация: 03.07.2009
Сообщений: 10,708
25.04.2010, 23:14 #5
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int main()
{
    int mas[256];
    int i = 0, len, imax = 0;
    while(i < 256) 
        mas[i++] = 0;
    char str[300];
    puts("input string:\n");
    gets(str);
    len = strlen(str);
 
    i ^= i;
    while(i < len)
        ++mas[(int)str[i++]];
    
    i ^= i;
    while(i++ < 255)
        if(mas[i] > mas[imax])
            imax = i;
    printf("symb = %s", (char)imax);
    return 0;
}
1
no0ker
101 / 88 / 4
Регистрация: 17.12.2010
Сообщений: 416
17.12.2010, 21:17 #6
а если рассмотреть следующий случай.
букв в строке - 100 000 000 (сто миллионов)
и нужно определить частоту букв, причем не только больших, но и маленьких.
как добиться приемлемой скорости алгоритма?

а если вместо букв какие то числа (скажем от 0 до 1 000 000)? и чисел этих около ста миллионов. и требуется распределение этих чисел по частоте. есть какой то более быстрый алгоритм?
0
M128K145
Эксперт JavaЭксперт С++
8320 / 3540 / 143
Регистрация: 03.07.2009
Сообщений: 10,708
18.12.2010, 10:16 #7
no0ker, используйте std::map, так будет проще
0
18.12.2010, 10:16
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.12.2010, 10:16
Привет! Вот еще темы с ответами:

Найти частоту букв в предложении - C++
Хелп!Нужно добавить возможность вводить слова при запуске проги. #include &lt;iostream&gt; #include &lt;string.h&gt; #include &lt;stdlib.h&gt; ...

Найти частоту букв в файле - C++
Программа читает текстовый файл и выводит частоту букв русского алфавита. Почему некоторые результаты на единицу меньше? Например...

Определить частоту появления в тексте каждого слова - C++
#include &lt;conio.h&gt; #include &lt;stdio.h&gt; #include &lt;ctype.h&gt; #include &lt;string.h&gt; main() { char tekst; char buf; ...

Строка: посчитать частоту появления каждого символа - C++
Для произвольного текста на произвольном языке с учетом регистра посчитать частоту появления каждого символа.


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru