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

Заменить в строке S все вхождения строки S1 на строку S2

02.12.2015, 07:54. Показов 3554. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Даны строки S , S1, S2. Заменить в строке S все вхождения строки S1 на строку S2 - C (СИ)
Миниатюры
Заменить в строке S все вхождения строки S1 на строку S2  
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.12.2015, 07:54
Ответы с готовыми решениями:

Заменить в строке все вхождения строки S1 на строку S2
Программа должна иметь текстовое меню, состоящие из подпрограмм. Каждая задачу реализовать двумя...

В первой строке заменить все вхождения строки 2 на строку 3
С клавиатуры вводится 3 строки . В первой строке заменить все вхождения строки 2 на строку 3....

Даны строки S, S0 и S2. Заменить в строке S все вхождения строки S0 на строку S2
Условие Даны строки S, S0 и S2. Заменить в строке S все вхождения строки S0 на строку S2. ...

Даны строки s, s1 и s2. Заменить в строке s все вхождения строки s1 на строку s2
Даны строки s, s1 и s2. Заменить в строке s все вхождения строки s1 на строку s2. Пример: вводим...

1
0 / 0 / 1
Регистрация: 01.12.2015
Сообщений: 11
03.12.2015, 14:44  [ТС] 2
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
void main()
{
char text[Nmax], text[Nmax], text[Nmax], text[Nmax];
int L, K;
printf_s(...);
gets_s(text);
printf_s(...);
gets_s(S1);
printf_s(...);
gets_s(S2);
 
char *S = strstr(text, S1);
 
while (S)
{
L = strlen(text);
K = L - strlen(S);
strcpy_s(A, S+ strlen(S1));
text[K] = '\0';
strcat_s(text, S2);
strcat_s(text, A);
S = strstr(text, S1);
}
 printf_s("...%s", text);
 
_getch();
}
Если не видно написал коротко

Добавлено через 1 час 45 минут
Ошибка
Debug assertion failed!
Program:...cumments\Visual studio 2013\Projects\Проект3\Debug\Проект3.exe
File:f:\dd\vctools\crt\crtw32\h\tcsat_s.inl
Line: 42
Expression : (L"Buffer is too small" && 0)

For information...

Добавлено через 12 часов 25 минут
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
#include <stdlib.h>
#include <stdio.h>
//#include <conio.h>
 
//Добавить к строке символ
char* stradd(char* src, int i, char c) {
    char* res;
    res = (char*)realloc(src, (i+1)*sizeof(char)); //Расширяем на один символ
    res[i] = c; //Приравниваем
    return res;
}
 
//Добавить к строке другую строку
char* strpush(char* src, int* i, const char* app) {
    while (*app!='\0') {
        src=stradd(src, *i, *app); //Добавляем текущий символ
        ++app; //Переходим к следующему символу в строке 2
        (*i)++; //Переходим к следующему символу в строке 1 
    }
    return src;
}
 
//Заменить in на to в src
//Результат нужно освободить функцией free
char* strreplace(const char* src, const char* in, const char* to) {
    char* res;
    const char* subsrc;
    int res_i, in_i;
    res = NULL;
    res_i = 0;
    while (*src!='\0') {
        in_i = 0;
        subsrc = src; //Заносим указатель на текущий символ строки в левую переменную
        while (*subsrc==in[in_i]) { //Прогоняем еще один цикл, пока подстрока совпадает
            ++subsrc; //Следующий элемент
            ++in_i;
            if (in[in_i]=='\0') { //Конец подстроки
                src = subsrc; //Смещаем текущий символ
                res = strpush(res, &res_i, to); //Добавляем подстроку to
                break;
            }
        }
        res = stradd(res, res_i, *src); //Добавляем текущий символ
        ++res_i;
        ++src; //Смещаем текущий символ
    }
    res = stradd(res, res_i, '\0'); //Чтобы строка заканчивалась нулем(чтобы библиотеки ее корректно принимали)
    return res;
}
 
int main(void) {
    char a[64];
    char b[64];
    char c[64];
    char* d;
    printf_s("Enter S string: ");
    gets_s(a);
    printf_s("Enter S1 string: ");
    gets_s(b);
    printf_s("Enter S2 string: ");
    gets_s(c);
    d = strreplace(a,b,c);
    printf("String after replacing: %s",d);
    free((void*)d);
    //gets_s();
    return 0;
}
Добавлено через 27 секунд
Писал брат, вроде работает без ошибок

Добавлено через 16 часов 21 минуту
Улучшенный вариант :
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
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
 
//Добавить к строке символ
char* stradd(char* src, int i, char c) {
    char* res;
    res = (char*)realloc(src, (i+1)*sizeof(char)); //Расширяем на один символ
    res[i] = c; //Приравниваем
    return res;
}
 
//Добавить к строке другую строку
char* strpush(char* src, int* i, const char* app) {
    while (*app!='\0') {
        src=stradd(src, *i, *app); //Добавляем текущий символ
        ++app; //Переходим к следующему символу в строке 2
        (*i)++; //Переходим к следующему символу в строке 1 
    }
    return src;
}
 
//Заменить in на to в src
//Результат нужно освободить функцией free
char* strreplace(const char* src, const char* in, const char* to) {
    char* res;
    const char* subsrc;
    int res_i, in_i;
    res = NULL;
    res_i = 0;
    while (*src!='\0') {
        while (1) {
            in_i = 0;
            subsrc = src; //Заносим указатель на текущий символ строки в левую переменную
            if (*subsrc!=in[in_i]) {break;}
            while (*subsrc==in[in_i]) { //Прогоняем еще один цикл, пока подстрока совпадает
                ++subsrc; //Следующий элемент
                ++in_i;
                if (in[in_i]=='\0') { //Конец подстроки
                    src = subsrc; //Смещаем текущий символ
                    res = strpush(res, &res_i, to); //Добавляем подстроку to
                    break;
                }
            }
        }
        res = stradd(res, res_i, *src); //Добавляем текущий символ
        ++res_i;
        ++src; //Смещаем текущий символ
    }
    res = stradd(res, res_i, '\0'); //Чтобы строка заканчивалась нулем(чтобы библиотеки ее корректно принимали)
    return res;
}
 
int main(void) {
    char a[64];
    char b[64];
    char c[64];
    char* d;
    printf("Enter S string: ");
    gets_s(a);
    printf("Enter S1 string: ");
    gets_s(b);
    printf("Enter S2 string: ");
    gets_s(c);
    d = strreplace(a,b,c);
    printf("String after replacing: %s",d);
    free((void*)d);
    _getch();
    return 0;
}
0
03.12.2015, 14:44
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.12.2015, 14:44
Помогаю со студенческими работами здесь

Даны строки S, S1 и S2. Заменить в строке S все вхождения строки S1 на строку S2
Задачу на массив оформить с помощью лямда выражений. Элементы массива получить с помощью Random

Даны строки s, s1 и s2. Заменить в строке s все вхождения строки s1 на строку s2
Даны строки s, s1 и s2. Заменить в строке s все вхождения строки s1 на строку s2. Пример: вводим...

Строки. Заменить в строке S все вхождения строки S1 на строку S2
помогите, пожалуйста.. даны строки S, S1 и S2. заменить в строке S все вхождения строки S1 на...

Заменить все вхождения строки s2 в исходную строку s1 на строку s3
даны три символьных строки s1 s2 s3. заменить все вхождения строки s2 в исходную строку s1 на...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Использование связки C# и PHP в корпоративной разработке и микросервисной архитектуре
InfoMaster 16.01.2025
Введение в интеграцию C# и PHP В современной корпоративной разработке все чаще возникает потребность в создании гибких и масштабируемых решений, способных эффективно решать широкий спектр. . .
Как использовать Kerio дома для управления сетью и пользователями
InfoMaster 16.01.2025
Использование технологий для улучшения повседневной жизни стало неотъемлемой частью современного быта. Одной из таких технологий является Kerio — мощный инструмент для управления сетью и. . .
Есть ли будущее у DVD и Blu-ray?
InfoMaster 16.01.2025
В эпоху стремительного развития цифровых технологий и повсеместного распространения потоковых сервисов вопрос о будущем физических носителей информации становится все более актуальным. Особенно остро. . .
Как проводить научные вычисления на Python
InfoMaster 15.01.2025
Python стал одним из наиболее востребованных языков программирования в области научных вычислений благодаря своей простоте, гибкости и обширной экосистеме специализированных библиотек. Научные. . .
Создание игры типа Minecraft на PyGame/Python: пошаговое руководство
InfoMaster 15.01.2025
В данном руководстве мы рассмотрим процесс создания игры в стиле Minecraft с использованием библиотеки PyGame на языке программирования Python. Этот проект идеально подходит как для начинающих. . .
Как создать свою первую игру в стиле Doom на Unreal Engine
InfoMaster 15.01.2025
Разработка шутера от первого лица в стиле классического Doom представляет собой увлекательное путешествие в мир игрового программирования, где сочетаются творческий подход и технические навыки. . . .
Параллельное программировани­е: основные технологии и принципы
InfoMaster 15.01.2025
Введение в параллельное программирование Параллельное программирование представляет собой фундаментальный подход к разработке программного обеспечения, который позволяет одновременно выполнять. . .
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru