Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 20, средняя оценка - 4.70
dolmatova22
17 / 0 / 1
Регистрация: 13.03.2010
Сообщений: 30
25.04.2010, 22:44     Найти частоту появления букв в строке #1
Найти частоту появления букв в строке. Определить наиболее часто встречаемую букву.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.04.2010, 22:44     Найти частоту появления букв в строке
Посмотрите здесь:

Установить частоту употребляемых букв C++
найти сколько гласных букв в строке C++
Строка: посчитать частоту появления каждого символа C++
В строке слов из букв латинского алфавита найти слова, в которых нет букв, которые повторяются. C++
C++ Массивы. Найти частоту появления каждого из m элементов, наиболее часто встречающиеся (m << n) в процентах
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
M128K145
Эксперт C++
 Аватар для M128K145
8272 / 3491 / 142
Регистрация: 03.07.2009
Сообщений: 10,707
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;
}
dolmatova22
17 / 0 / 1
Регистрация: 13.03.2010
Сообщений: 30
25.04.2010, 23:03  [ТС]     Найти частоту появления букв в строке #3
Можно на СИ ?
delfamur
 Аватар для delfamur
42 / 42 / 0
Регистрация: 16.03.2010
Сообщений: 199
25.04.2010, 23:04     Найти частоту появления букв в строке #4
хм...тут даже алгоритм большой. создаешь массив чар всех букв обоих регистров. то, что вводим с клавы тоже в чар. начинаем цикл, внутри условие на равенство элемента массива и элемента введеной строки. если равно - (тут тоже удобнее использовать массив, но уже инт) мас[индекс_буквы]++; вот тебе и частота. а потом уже максимальный элемент массива инт и по его индексу вывести букву массива чар
M128K145
Эксперт C++
 Аватар для M128K145
8272 / 3491 / 142
Регистрация: 03.07.2009
Сообщений: 10,707
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;
}
no0ker
100 / 87 / 4
Регистрация: 17.12.2010
Сообщений: 416
17.12.2010, 21:17     Найти частоту появления букв в строке #6
а если рассмотреть следующий случай.
букв в строке - 100 000 000 (сто миллионов)
и нужно определить частоту букв, причем не только больших, но и маленьких.
как добиться приемлемой скорости алгоритма?

а если вместо букв какие то числа (скажем от 0 до 1 000 000)? и чисел этих около ста миллионов. и требуется распределение этих чисел по частоте. есть какой то более быстрый алгоритм?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.12.2010, 10:16     Найти частоту появления букв в строке
Еще ссылки по теме:

Найти количество прописных букв в строке C++
C++ Найти частоту появления символов в исходном текстовом файле

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

Или воспользуйтесь поиском по форуму:
M128K145
Эксперт C++
 Аватар для M128K145
8272 / 3491 / 142
Регистрация: 03.07.2009
Сообщений: 10,707
18.12.2010, 10:16     Найти частоту появления букв в строке #7
no0ker, используйте std::map, так будет проще
Yandex
Объявления
18.12.2010, 10:16     Найти частоту появления букв в строке
Ответ Создать тему
Опции темы

Текущее время: 12:03. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru