Язык СИ. Строки и использование библиотечных функций для их обработки

Модераторы: Hawk, Romeo, Absurd, DeeJayC, WinMain

Ответить
Sanych89
Сообщения: 1
Зарегистрирован: 05 дек 2009, 20:28

Задание : В предложении найти все однокоренные слова.
Корень задается с клавиатуры.
Делал по похожему примеру - но не получилось((((

Код ниже, подскажите в чем ошибка???

Код: Выделить всё

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define N 20

// ПРЕДВАРИТЕЛЬНОЕ ОБЪЯВЛЕНИЕ ФУНКЦИЙ
// Заголовок программы
void Title();
// Ввод предложения
void InpPredl (char predl[]);
// Выделение из предложения
void Select(const char *predl, char m[][N],char *sel, int *n);
// Сборка предложения
char *Constructor(char slova[][N], char razd[][N], int sl, int rz);
// Вывод результата
void OutPredl(char *s1, char *s2);

void Odnokor(char slova[][N], int sl)
{ int i; char [];
  for(i=0;i<=sl;i++)
  puts(slova[i]);
}

int main()
{
    // ОБЪЯВЛЕНИЕ ПЕРЕМЕННЫХ
    char predl[80]; // Введенное предложение
    char slova[N][N]; // Массив слов в предложении
    char *r="`!;:,.?- "; // Разделительные знаки
    int sl=-1, rz=-1; // Счетчики слов и разделителей
    char *b = "qqwertyuioplkjhgfdsazxcvbnmQWERTYUIOPLKJHGHFDSAZXCVBNM";
    char razd [N][N]; // Массив разделителей в предложении
    char *res; // Результирующее предложение

    // Заголовок программы
   // Title ();
    // Ввод предложения
    InpPredl (predl);
    // Выделение из предложения слов
Select (predl, slova, r, &sl);
// Выделение из предложения разделителей
Select (predl, razd, b, &rz);
// Сборка предложения
res = Constructor(slova, razd, sl, rz);
// Вывод результата
OutPredl (predl, res);
free (res);
Odnokor(slova,sl);

    return 0;
}

// Заголовок программы
void Title()
{
//clrscr ();
puts (" LABOROTORNOE ZADANIE N 8");
puts (" V PREDLOZENII NAITI VSE ODNOKORENNIE SLOVA");
puts (" KOREN ZADAETSYA S KLAVUATURI.");
puts(" PORYADOK SLEDOVANIA ZNAKOV PREPINANIA NE MENYAT.");
puts(" V PREDLOZHENII ISPOLYZYEUTSA RUSSKIE BURVI I ZNAKI. \n");
}
// Ввод предложения
void InpPredl(char *s)
{
puts(" vvedite predlozhenie \n");
strcpy (s," verite li vi, chto zadacha reshena?");
// gets (s);

}
// Выделение из предложения
void Select(const char *predl, char m[][N], char *sel, int *n)
{
char *p, *s;
s=strdup (predl); // Сделать копию исходного предложения
// так как передается константа, strtok требует
// внесения изменений при своей работе
p = strtok (s, sel);
while (p)
{
(*n)++;
strcpy (m[*n],p);
p = strtok (NULL, sel);
}
free (s);
}
// Вывод результата
void OutPredl (char *s1, char *s2)
{
puts ("ichodnoe predlozhenie");
puts (s1);
puts (" Rezultat ");
puts (s2);

}
// Сборка предложения
char *Constructor(char slova[][N], char razd[][N], int sl, int rz)
{
int i, j;
char res[80];
char *s;
*res=0; // Начальное значение результата
i = sl;
j=-1;
while ((i>=0)||(j<=rz))
{
if ((i>=0)) strcat (res, slova[i]); // Добавление слова
i--;
j++;
if ((j<=rz)) strcat (res, razd[j]); // Добавление знаков
}
s = strdup (res);
return s;
}
Ответить