Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
 Аватар для SadiQ228
-4 / 24 / 7
Регистрация: 16.12.2016
Сообщений: 716

Имея массив указателей на слова, подсчитать слово, встречающееся чаще всего

21.04.2018, 03:26. Показов 976. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня есть массив указателей на слова, как подсчитать слово встречающееся чаще всего?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.04.2018, 03:26
Ответы с готовыми решениями:

Найти в строке слово, встречающееся чаще всего
Задача найти в строке слово ,встречающееся чаще всего. Ввожу строку ,делю её на слова и их в массив слов. Вопрос собственное как потом...

Подсчитать сколько раз в тексте встречается каждое слово и удалить то слово, которое встречается чаще всего
Само задание : Вводим текст и для каждого из слов указать, сколько раз оно встречается в тексте. Слово, чаще всего встречающееся в тексте,...

Слово, встречающееся чаще всего
Runtime error( Дан текст. Выведите слово, которое в этом тексте встречается чаще всего. Если таких слов несколько, выведите то, которое...

7
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
21.04.2018, 04:29
завести массив количеств слов
0
3 / 3 / 3
Регистрация: 02.03.2015
Сообщений: 40
21.04.2018, 05:34
Переделай

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
#include <stdio.h>
#define N 15
main() {
    short arr[N];
    short i, k, num, frq, max_frq;
    srand(time(NULL));
    for (i=0; i<N; i++) {
        arr[i] = rand() % 20;
        printf("%d ", arr[i]);
    }
    printf("\n");
 
    num = arr[0];
    max_frq = 1;
    for (i=0; i < N-1; i++) {
        frq = 1;
        for (k = i+1; k<N; k++) 
            if (arr[i] == arr[k])
                frq += 1;
        if (frq > max_frq) {
            max_frq = frq;
            num = arr[i];
        }
    }
 
    if (max_frq > 1) 
        printf("%d раз(а) встречается число %d\n", max_frq,num);
    else
        printf("Все элементы уникальны!\n");
}
0
 Аватар для SadiQ228
-4 / 24 / 7
Регистрация: 16.12.2016
Сообщений: 716
21.04.2018, 23:14  [ТС]
имею файл с содержанием:
I've been fuckin' hoes and poppin' pillies
Man, I feel just like a rockstar (star, ayy, ayy)
All my brothers got that gas
And they always be smokin' like a Rasta ('sta)
Fuckin' with me, call up on a Uzi
And show up, man, them the shottas ('tas)
When my homies pull up on your block
They make that thing go grrra-ta-ta-ta (ta, pow, pow, pow)
построчно передаю его в функцию, которая находит слова, и выделяет динамически место для слов.
однако на выводе получаю дубляж некоторых слов, с чем это связанно?
ВЫВОД ПРОГРАММЫ:
Кликните здесь для просмотра всего текста
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
FILE OPEN: OK
I
ve
been
fuckin
fuckin
hoes
and
poppin
poppin
pillies
Man
Man
I
feel
just
like
a
rockstar
rockstar
star
star
ayy
ayy
ayy
All
my
brothers
got
that
gas
And
they
always
be
smokin
smokin
like
a
Rasta
Rasta
Rasta
sta
Fuckin
Fuckin
with
me
me
call
up
on
a
Uzi
And
show
up
up
man
man
them
the
shottas
shottas
shottas
tas
When
my
homies
pull
up
on
your
block
They
make
that
thing
go
grrra
ta
ta
ta
ta
ta
ta
pow
pow
pow
pow
pow
FIND WORD  &&  GET ptrARR: OK
Для продолжения нажмите любую клавишу . . .

попутно спрошу сразу как записывать найденные слова в массив указателей?

код:
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
void FindWordGetMass(char*buf)
{
    int count;
    char * letters =NULL;
    char * FoundWord=NULL;
 
    for (unsigned int i = 0; i < strlen(buf) - 1; i++)
    {
        if (((buf[i] >= 'a') && (buf[i] <= 'z')) || ((buf[i] >= 'A') && (buf[i] <= 'Z')))
        {
            count = 0;
            letters = NULL;
            FoundWord = NULL;
            do {
                count++;
                letters = (char*)realloc(FoundWord, count * sizeof(char)); // при добавлении новой буквы, увеличиваем массив на 1
                if (letters != NULL)
                {
                    FoundWord = letters;
                    FoundWord[count - 1] = buf[i++];                      // добавить к массиву следующую букву
                }
                else
                {
                    free(FoundWord);
                    printf("MEMORY ALLOCATION ERROR");
                    exit(666);
                }
            } while (((buf[i] >= 'a') && (buf[i] <= 'z')) || ((buf[i] >= 'A') && (buf[i] <= 'Z')));
            count++;
            letters = (char*)realloc(FoundWord, count * sizeof(char));
            if (letters != NULL)
            {
                FoundWord = letters;
                FoundWord[count - 1] = '\0';
            }
            else
            {
                free(FoundWord);
                printf("MEMORY ALLOCATION ERROR");
                exit(666);
            }
        }
        printf("%s\n", FoundWord);
    }
 
 
}
Добавлено через 3 минуты
я так понял что дублирует слово , сразу после которого идет какой то символ который не пробел, почему так?
0
 Аватар для SadiQ228
-4 / 24 / 7
Регистрация: 16.12.2016
Сообщений: 716
22.04.2018, 00:46  [ТС]
при отладке, когда дело доходит до строки с realloc дебаггер вылетает с ошибкой
Миниатюры
Имея массив указателей на слова, подсчитать слово, встречающееся чаще всего  
0
 Аватар для SadiQ228
-4 / 24 / 7
Регистрация: 16.12.2016
Сообщений: 716
22.04.2018, 00:53  [ТС]
UPD:
старый дедовский printf после каждой сомнительной строчки выявил причину дублей - неверное расположение принтф)))

вопрос про массив указателей все еще стоит остро не могу придумать
0
 Аватар для CoderHuligan
1744 / 1009 / 257
Регистрация: 30.06.2015
Сообщений: 5,120
Записей в блоге: 56
22.04.2018, 10:56
Цитата Сообщение от SadiQ228 Посмотреть сообщение
вопрос про массив указателей все еще стоит остро не могу придумать
А чего тут думать - используй strtok()
Цитата Сообщение от SadiQ228 Посмотреть сообщение
for (unsigned int i = 0; i < strlen(buf) - 1; i++)
Кто в си использует такое? Тебя же засмеют если кому покажешь. strlen из цикла вынеси, это тебе не паскаль.
Цитата Сообщение от SadiQ228 Посмотреть сообщение
exit(666);
А это что такой прикол? Может поэтому ничего не получается?
0
 Аватар для SadiQ228
-4 / 24 / 7
Регистрация: 16.12.2016
Сообщений: 716
23.04.2018, 01:41  [ТС]
насчет strtok можно чуть более подробно?

прикол про strlen не понял? че смешного? как задавать без него условие?

exit(666) работает без нареканий, ведь до него дело не доходит)))

Добавлено через 10 часов 42 минуты
не верно написал задание, настоящее гласит "Вывести слова, длина которых встречается в файле чаще всего"

мое решение:

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
void MostOftenWord(char ** Array, int &wordCounter)
{
    int LenCount[BufSize] = { 0 };
    int Len;
    int WordSimbols = 0;
    int MAX_ELEMENTS = 1;
 
    for (int i = 0; i < wordCounter; i++)
    {
        Len = strlen(Array[i]);
        LenCount[Len] = LenCount[Len]++;
        if (LenCount[Len] > MAX_ELEMENTS)
        {
            MAX_ELEMENTS++;
            WordSimbols = Len;
        }
    }
    if (MAX_ELEMENTS > 1)
    {
        printf("Words with [%d] simbols was found [%d] times:\n", WordSimbols, MAX_ELEMENTS);
        for (int i = 0; i < wordCounter; i++)
        {
            if (strlen(Array[i]) == WordSimbols)
            {
                printf("[%s]\n", Array[i]);
            }
        }
    }
    else
    {
        printf("ALL WORDS ARE UNIQUE");
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.04.2018, 01:41
Помогаю со студенческими работами здесь

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

Как найти число, встречающееся чаще всего?
Всем привет! Нужна небольшая помощь с задачкой. Вот собственно и она: ...

С помощью указателей найти и напечатать число, чаще других встречающееся в массиве
1 задача с++ В динамической памяти ЭВМ Сформировать массив 100 целых случайных чисел в диапазоне от 0 до 9. Напечатать его. С помощью...

Какая цифра в строке встречается чаще всего (выполнить с помощью указателей)
написать программу, которая до введенного с клавиатуры строки (максимальная длина строки - 80 символов) сообщает, какая цифра в ней...

Дан текст, а также 2 слова. Заменить встречающееся в тексте слово 1 на слово 2
Подскажите пожалуйста, как написать программу в visual basic 6.0, если: Дан текст, а также 2 слова. Заменить встречающееся в тексте...


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

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