Форум программистов, компьютерный форум CyberForum.ru

Удаление слова из строки - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Программирование циклов с неизвестным заранее числом повторений http://www.cyberforum.ru/cpp-beginners/thread424109.html
вот еще лабораторная, как её делать ума не приложу, и одногруппники тоже сделать не могут. если кто сделает, пожалуйста добавьте алгоритмы, алгоритмы тоже нужны. Выкладывайте задания в теме. Не все из способных вам помочь захотят что-то там скачивать... Лабораторная работа №3 Программирование циклов с неизвестным заранее числом повторений Цель работы: освоение средств языка C++ для...
C++ разбить квадратную матрицу на 4 части подскажите, как разбить квадратную матрицу размерностью n на 4 матрицы с размерностью n/2 http://www.cyberforum.ru/cpp-beginners/thread424104.html
Описать класс для работы с целочисленной матрицей произвольного размера C++
Составить класс для работы с целочисленной матрицей произвольного размера, который задается в конструкторе,где данная матрица создается динамически. Включить саму матрицу во внутреннюю часть класса. Во внешней части задать и реализовать следующие функции-методы: -функция автоматического (через функцию rand) заполнение матрицы значениями из диапазона от -N до N (данный параметр передаются в...
Спецификация файла. WTF? C++
Здравствуйте. Что такое спецификация файла (в контексте данной задачи)? В Google ничего понятного не нашел. Заранее спасибо.
C++ Используя функции и режим меню, создать файл из 10 структур, просмотреть файл, добавить в файл новую информацию и, применяя режим прямого доступа, Выв http://www.cyberforum.ru/cpp-beginners/thread424087.html
Здравствуйте! Если кто-нибудь мог бы помочь в решении только той части где касается написания функции о поиске самого высокого спортсмена из 10 созданных структур.(if r.rost>r.rost) я просто не знаю как именно. Была бы очень благодарна. Используя функции и режим меню, создать файл из 10 структур, просмотреть файл, добавить в файл новую информацию и, применяя режим прямого доступа, Вывести...
C++ Программирование циклов с параметром. Одномерные массивы ужас, помогите решить лабораторную, завтра экзамен, а у меня не сделано, я вообще не понимаю как это делать! подробнее

Показать сообщение отдельно
-=ЮрА=-
Заблокирован
Автор FAQ
08.01.2012, 00:31     Удаление слова из строки
Цитата Сообщение от KSTU Посмотреть сообщение
Задание:
Необходимо обработать текстовый файл. В первой строке файла указано
общее число строк. Выделить память под массив указателей на строки,
ввести текст построчно, динамически выделяя память для хранения каждой
строки и записывая указатель в массив. Вывести на экран исходный текст.
Выполнить один из вариантов обработки текста.
Вариант:
Удалить все вхождения заданного слова из текста.
- ниже алгоритм на Си реализующий динамическое выделение памяти, а также удаление введенного слова
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
#include <stdio.h>  //fscanf printf
#include <string.h> //strstr strcpy
#include <stdlib.h> //malloc
 
char * getLine(FILE * f, long lpos, char * s)
{
    char symbol;
    fseek(f,0,SEEK_END);
    long sLen = 0;
    long fLen = ftell(f);
    if(lpos < fLen)
    {
        fseek(f,lpos,SEEK_SET);
        do
        {
            fscanf(f,"%c",&symbol);
            if(feof(f))//Нужно для последней строки файла
                symbol = '\n';
            if(s != NULL && symbol != '\r')
            {
                //каждый раз увеличиваем длинну строки на символ (sLen = sLen + 1)
                s = (char *)realloc((void *)s,((sLen = sLen + 1) + 1)*sizeof(char));
                s[sLen - 1] = symbol;//вставляем считанный символ в строку
            }
        }
        while(symbol != '\n' && !feof(f));
        s[sLen] = '\0';
    }
    return s;
}
 
char * remWord(char * s, char * word)
{
    long sLen = 0;
    long wLen = 0;
    long nChr = 0;
    char * substr = NULL;
    if(s != NULL && word != NULL)
    {
        wLen = strlen(word);
        while((substr = strstr(s,word)))
        {
            nChr = strlen(s);
            sLen = strlen(substr);
            strcpy(&s[nChr - sLen],&s[nChr - sLen + wLen]);
        }
    }
    return s;
}
 
int main()
{
    long i;
    long nLines   = 0;
    char ** Lines = NULL;
    char word[256]= {0};//Думаю слова даже в 32 чара нет а 256 хватит с головой!
    FILE * f = NULL;
    system("chcp 1251");
    if(!(f = fopen("text.txt","r")))
        printf("Error open text.txt\n");
    else
    {
        fscanf(f,"%u",&nLines);
        fseek(f,ftell(f) + strlen("\r\n"),SEEK_SET);
        printf("Input text : \n");
        Lines = (char **)malloc(nLines*sizeof(char *));
        for(i = 0; i < nLines && !feof(f); i++)
        {
            Lines[i] = (char *)malloc(sizeof(char));
            Lines[i] = getLine(f, ftell(f), Lines[i]);
            printf("%s",Lines[i]);
        }
        fclose(f);
        printf("Enter word removing from text : ");
        scanf("%s",word);
        for(i = 0; i < nLines; i++)
        {
            Lines[i] = remWord(Lines[i], word);
            printf("%s",Lines[i]);
        }
    }
    system("pause");
    return 0;
}
PS:Память не чистил, т.к. приложение отрабатывает всего 1 раз - ОС и сама способна за ним мусор почистить, на суть алгоритма это не влияет поэтому и не приводил
text.txt
10
sdgjsdjkg jgf jdfjlgj j jfsgj j jjg REM jfjgfdj jdgfjfd
jgsdgj 4g4d5f 15fg4df5 415fg 5fg4d4 1vs5f 4g 5g5d 5g4f
sdg;dsk jfg
REM REM fjkgjndj fjdgkgfk gmgd
fgfd kfdkk
sdlgkds dfkgk mdfj
sdkgk
sdgkdfkgkg REM
REM REM
dhfsdf jg REM
Миниатюры
Удаление слова из строки  
 
Текущее время: 01:54. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru