Сортировка слов по алфавиту

Мне нужно сделать программу, которая может сортировать слова по алфавиту от а до я. текущая программа, которую я создал, способна сортировать слова, но только если она находится на новой строке (‘\ n’).

Слова, которые находятся дальше в строке, не сортируются.

Вот код:

#include <stdio.h>
#include <stdlib.h>
#include <strings.h>
#define SIZE 30
#define LEN 31

void bron (char *fnamer)
{
printf("\nGeef de naam van de in te lezen txt file: \n");
gets(fnamer);
//getchar(fnamer);
}

void uitgave (char *fnamer2)
{
printf("\nGeef de naam van de nieuwe geschreven txt file: \n");
gets(fnamer2);
//getchar(fnamer2);
}

int main()
{
char name[LEN][SIZE];
char hold[LEN] ;
int i,j ;
int last ;
FILE *fp;
FILE *fp2;

char ch;
char fnamer[1000];
char fnamer2[1000];

bron(fnamer);

fp=fopen(fnamer,"r");
if(fp==NULL)
{
printf("Error!");
exit(1);
}
uitgave(fnamer2);
fp2=fopen(fnamer2,"w");
if(fp2==NULL)
{
printf("Error!");
exit(1);
}
else
{

for(i = 0 ; !feof(fp) ; i++ )

{
fgets( name[i] , LEN, fp);
}
last = i - 1 ;

fclose(fp);

for (i = last ; i > 0 ; i--)
for (j = 1 ; j <= i ; j++)

if (strcmp(name[j],name[j - 1]) < 0)
{
strcpy(hold,name[j]) ;
strcpy(name[j],name[j - 1]) ;
strcpy(name[j - 1],hold) ;
}

for (i = 0 ; i <= last ; i++)
{
printf("%s",name[i]) ;
// fprintf("%s", name [i]); herzien
}

}
printf("\n%s \t%s",fnamer,fnamer2) ;
//fprintf(fp, %s) ; // herzien
fclose(fp2);
return 0;
}

В чем проблема?

0

Решение

Да, это правильно. Но я не могу найти, где это идет не так. Прежде всего. я не могу управлять программным фургоном, записывая слова в текстовый файл, и, во-вторых, я понятия не имею, как дать программе правильный код для просмотра всех слов, а не только слов в новой строке.

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]