C программа для поиска трека в массиве треков - PullRequest
2 голосов
/ 24 февраля 2020

У меня есть программа, которая должна выводить название и номер дорожки на основе текстового ввода (например, ввод 'town' должен выводить "Track 1: 'Newark, Newark - замечательный город'"), но вывод в настоящее время пуст (ничего не возвращается, программа просто прекращает выполнение без ошибок). Вот программа:

#include <stdio.h>
#include <string.h>

char tracks[][80] = {
"I left my heart in Harvard Med School",
"Newark, Newark - a wonderful town",
"Dancing with a Dork",
"From here to maternity",
"The girl from Iwo Jima",
};

void find_track(char search_for[])
{
    int i;
    for (i = 0; i < 5; i++){
        if (strstr(tracks[i], search_for))
            printf("Track %i: '%s'\n", i, tracks[i]);
    }
}

int main()
{
    char search_for[80];
    printf("Search for: ");
    fgets(search_for, 80, stdin);
    find_track(search_for);
    return 0;
}

Пожалуйста, помогите:)

1 Ответ

4 голосов
/ 24 февраля 2020
fgets(search_for, 80, stdin);

ловит символ новой строки \n, тянущий за правильным вводом строки, сделанным нажатием клавиши, на Return и записывает его в search_for.


. Лучший способ удалить это лучше всего объяснено в этом ответе до Удаление завершающего символа новой строки из ввода fgets () .

Использование strcspn() для:

search_for[strcspn(search_for, "\n")] = 0;

перед вызовом

find_track(search_for);

удалить или лучше сказать, заменить его на \0.


Весь код будет тогда:

#include <stdio.h>
#include <string.h>

char tracks[][80] = {
"I left my heart in Harvard Med School",
"Newark, Newark - a wonderful town",
"Dancing with a Dork",
"From here to maternity",
"The girl from Iwo Jima",
};

void find_track(char search_for[])
{
    int i;
    for (i = 0; i < 5; i++){
        if (strstr(tracks[i], search_for))
            printf("Track %i: '%s'\n", i, tracks[i]);
    }
}

int main()
{
    char search_for[80];
    printf("Search for: ");
    fgets(search_for, 80, stdin);
    search_for[strcspn(search_for, "\n")] = 0;    // here is the change.
    find_track(search_for);
    return 0;
}
...