Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/29: Рейтинг темы: голосов - 29, средняя оценка - 4.97
0 / 0 / 0
Регистрация: 28.03.2019
Сообщений: 5
1

Qsort для динамического массива строк

28.03.2019, 10:12. Показов 6035. Ответов 3

Author24 — интернет-сервис помощи студентам
На вход подается некоторый текст длинной не больше 1000 слов, каждое длиной не больше 50 символов(слова могут быть разделены только пробелом или точкой), и на следующей строке подается слово, которое необходимо найти в этом тексте. Программа сначала разбивает текст на слова и записывает каждое слово как отдельный элемент в динамическом массиве строк, а затем использует функции стандартной библиотеки qsort и bsearch, чтобы найти слово. В конце выводится exist, если слово было найдено и doesn't exist в противном случае.
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define TEXT_LEN 1000
#define WORD_LEN 50
 
int cmpfunc(const void* a, const void* b)
{
    const char* aa = *(const char**)a;
    const char* bb = *(const char**)b;
    return strcmp(aa,bb);
}
 
 
 
int main(){
    char str[31];
    char *cut = NULL;
    int * pItem = NULL;
    int check = 0;
    char **lined_text = malloc(TEXT_LEN * sizeof(char*));
    for(int m=0; m < TEXT_LEN; m++){
        lined_text[m] = malloc(WORD_LEN * sizeof(char));
    }
    char *text = malloc(TEXT_LEN+1 * sizeof(char));
    int i = 0;
    fgets(text, TEXT_LEN , stdin);
    scanf("\n");
    fgets(str, 31, stdin);
    char tokens[4]=" .";
    cut = strtok(text,tokens);
    while(cut != NULL){
        strcpy(lined_text[i], cut);
        cut = strtok(NULL, tokens);
        i++;
    }
 
    qsort (lined_text, (i-1), sizeof(char*), cmpfunc);
 
    pItem = (int*) bsearch (&str, lined_text, (i-1), sizeof(char*), cmpfunc);
    if (pItem!=NULL)
        printf ("exists");
    else
        printf ("doesn't exist");
 
    free(text);
    return 0;
}
Понимаю, что выделение памяти не оптимизировано, но это не главная задача. Предполагаю, что программа падает где-то в начале цикла while, но не уверен на 100%
Помогите пожалуйста отладить
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
28.03.2019, 10:12
Ответы с готовыми решениями:

Qsort динамического массива
Что я делаю не так? int cmp (const void *a, const void *b){ return (*(int*)a - *(int*)b); }...

Создание динамического массива строк
Задача состоит в следующем: из массива строк нужно найти подстроки по заданному условию (например,...

Многократное пересоздание динамического массива строк
Вопрос в шапке, возможно ли такое? Передо мной встала такая задача, что нужно в цикле постоянно...

Qsort для строк
Добрый день. Не работает qsort для строк. Не могу понять в чем дело :(. Есть массив указателей на...

3
724 / 224 / 72
Регистрация: 01.03.2011
Сообщений: 629
28.03.2019, 11:51 2
Не запускал, чисто глазами. Падать оно должно в на bsearch() в cmpfunc(). Вы подаете в bsearch указатель на str, а cmpfunc() ждет указатель на указатель.
0
Эксперт CЭксперт С++
5117 / 4556 / 854
Регистрация: 07.10.2015
Сообщений: 9,462
28.03.2019, 12:45 3
Лучший ответ Сообщение было отмечено Brooch как решение

Решение

Brooch, держите исправленный код. Внимательно сравните...
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <malloc.h>
#define TEXT_LEN 1000
#define WORD_LEN 50
 
int cmpfunc(const void* a, const void* b)
{
    const char* aa = *((const char**)a);
    const char* bb = *((const char**)b);
    return strcmp(aa, bb);
}
 
int cmpfunc2(const void* key, const void* b)
{
    const char* bb = *((const char**)b);
    return strcmp((const char*)key, bb);
}
 
 
int main() {
    char str[31];
    char *cut = NULL;
    char *key = NULL;
    int * pItem = NULL;
    int check = 0;
    char **lined_text = (char**)malloc(TEXT_LEN * sizeof(char*));
    for (int m = 0; m < TEXT_LEN; m++) {
        lined_text[m] = (char*)malloc(WORD_LEN * sizeof(char));
    }
    char *text = (char*)malloc(TEXT_LEN + 1 * sizeof(char));
    int i = 0;
    fgets(text, TEXT_LEN, stdin);
    fgets(str, 31, stdin);
    char tokens[4] = " .\n";
    cut = strtok(text, tokens);
    while (cut != NULL) {
        strcpy(lined_text[i], cut);
        cut = strtok(NULL, tokens);
        i++;
    }
    key = strtok(str, tokens);
 
    qsort(lined_text, i, sizeof(char*), cmpfunc);
 
    pItem = (int*)bsearch (key, lined_text, i, sizeof(char*), cmpfunc2);
    if (pItem != NULL)
        printf ("exists\n");
    else
        printf ("doesn't exist\n");
 
    for (int m = 0; m < i; m++)
        free(lined_text[m]);
    free(lined_text);
    free(text);
    system("pause");
    return 0;
}
1
0 / 0 / 0
Регистрация: 28.03.2019
Сообщений: 5
28.03.2019, 21:43  [ТС] 4
liv, огромное Вам спасибо, очень сильно меня выручили!)))
0
28.03.2019, 21:43
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.03.2019, 21:43
Помогаю со студенческими работами здесь

Qsort для массива структур
Да, знаю, что таких тем на форуме уже полно, как и кода, но смысл мне всё равно непонятен. Есть...

Создание динамического массива строк
Всем доброго утра/вечера/дня. Возникла такая проблема. Не могу создать динамический массив строк....

СОртировка динамического массива строк
#include &lt;conio.h&gt; #include &lt;stdio.h&gt; #include &lt;locale&gt; #include &lt;iostream&gt; #include &lt;string.h&gt;...

Удаление динамического массива строк
Здравствуйте! У меня проблема с удалением массива строк.Создал класс с полем - char** str;...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru