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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Nike0
6 / 6 / 0
Регистрация: 29.11.2009
Сообщений: 55
#1

Строки в С - C++

28.11.2010, 15:14. Просмотров 554. Ответов 7
Метки нет (Все метки)

Доброго времени суток. Появился вопрос: есть ли в чистом Си функция Replace(s, s1, s2)?
Например: s - "Шла Маша по шоссе", s1 - "а", s2 - "и". Тогда должно получиться "Шли Миши по шоссе".
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.11.2010, 15:14     Строки в С
Посмотрите здесь:

Ввести строки и через n символов первой строки вставить вторую строку, и так до конца строки - C++ Builder
Помогите исправить баг задача состоит в следующем :ввести строку и простроку тоесть две строки и надо через (n) символов первой строки...

Даны три строки. Определить можно ли из символов третьей строки получить первую и вторую строки - Java
Помогите пожалуйста! 1)Даны три строки. Определить можно ли из символов третьей строки получить первую и вторую строки. 2)Дана...

Слить две строки, вставив символы одной строки между символами другой строки - Pascal
Строка a из n символов лексикографически меньше строки b из n символов, если существует такой индекс j, что aj < bj, а для всех i < j ai =...

Сравнить строки, первый несовпадающий элемент строки-приемника записать в регистр AL, строки-источника - в DL - Assembler
Помогите написать программу на ассемблерене совсем еще разобрался с этим задание: Ввести с клавиатуры две строки одноразрядных...

Определить длину строки. Если длина строки >6, удалить часть строки в { } скобках. - Turbo Pascal
Ввести с клавиатуры строку символов. Признак окончания ввода строки – нажатие клавиши "Ввод". Программа должна определить длину введенной...

Строки. Если в конце строки точка отсутствует, то найти слово, заканчивающееся точкой и перенести его в конец строки. - Pascal
Дана строка, состоящая из слов и содержащая одну точку в конце одного из слов. Если в конце строки точка отсутствует, то найти слово,...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
legend
28 / 27 / 0
Регистрация: 17.11.2010
Сообщений: 152
28.11.2010, 15:21     Строки в С #2
я не знаю чистое ли єто СИ но есть ф-ция swap (s1,s2)

можно менять и вручную, для этого добавить одну переменную.
k=s1;
s1=s2;
s2=k;
Nike0
6 / 6 / 0
Регистрация: 29.11.2009
Сообщений: 55
29.11.2010, 11:50  [ТС]     Строки в С #3
если не тяжело, можно с примером кода этой функции, чтобы меняло соответствующие строки?
Nike0
6 / 6 / 0
Регистрация: 29.11.2009
Сообщений: 55
06.12.2010, 19:14  [ТС]     Строки в С #4
я в инете порыскал, почитал, пишут сложный алгоритм для описания
этой функции, нашел одну ссылку edu.nstu.ru/courses/inform/itpr/
demo/bk34-09.htm, там вроде как алгоритм описан, и если кому-то не
сложно, прошу напмсать это счастье с указателями, не дружу я с
ними к сожалению, а конкретно со строками
Nike0
6 / 6 / 0
Регистрация: 29.11.2009
Сообщений: 55
09.12.2010, 14:34  [ТС]     Строки в С #5
появился вопрос, когда строка для поиска равна заменяемой, все проделывает, только немного кривовато, а когда больше или меньшее вообще зацикливается, может кто найти ошибку?
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
#include <stdio.h>
#pragma hdrstop
#include <conio.h>
#include <tchar.h>
#include <string.h>
#define N 80
#pragma argsused
 
int main()
{
    char s[N],s1[N],s2[N];
    int n;
    clrscr();
    printf("Vvedite stroku s:\n");
    gets(s);
    printf("\nVvedite stroku s1:\n");
    gets(s1);
    printf("\nVvedite stroku s2:\n");
    gets(s2);
    for (n = 0; s[n] != '\0'; n++)
    {
        int i;
        for (i=0; s[n+i] !='\0' && s1[i] !='\0'; i++)
            if (s[n+i] != s1[i])
                break;
        if (s1[n+i]=='\0')
        {
                        int l2,dd,k;
            l2 = strlen(s2);
            dd = l2 - strlen(s1);
            if (dd != 0)
            {
                                if (dd < 0)
                {
                    for (k=n; s[k+dd]!='\0'; k++)
                        s[k] = s[k+dd];
                        s[k]='\0';
                }
                else
                {
                    for (k=n; s[k]!='\0'; k++)
                        for (; k != n; k--)
                            s[k+dd] = s[k];
 
                }
            }
            for (k = 0; k < l2; k++)
                s[n+k] = s2[k];
        }
    }
    printf("%s",s);
    getch();
    return 0;
}
KOHCEPBATOP
2 / 2 / 1
Регистрация: 27.04.2010
Сообщений: 11
09.12.2010, 15:00     Строки в С #6
Nike0, попробуй сравнивать строки с помощью функции strmcmp и результат в процессе работы помещать во временную строку s4[N] (а по окончании обработки скопировать в S).
Nike0
6 / 6 / 0
Регистрация: 29.11.2009
Сообщений: 55
11.12.2010, 14:44  [ТС]     Строки в С #7
KOHCEPBATOP, эта функция будет возвращать -1, 0 или 1, а у меня dd может равнятся и -3, и 3 например, поэтому strncmp не катит
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.01.2011, 22:29     Строки в С
Еще ссылки по теме:

Строки. Определить длину введенной строки, если длина кратна 4, то первая часть строки меняется местами со второй - Turbo Pascal
Ввести с клавиатуры строку символов.признак окончания ввода строки-нажатие клавиши ввод.Программа должна определить длину введенной строки...

Сгенерировать две произвольные строки и определить, является ли какое-либо слово первой строки частью второй строки - C++
Сгенерировать две произвольные строки и определить, является ли какое-либо слово первой строки частью второй строки. 1. Я дуб дубом,даже...

БД с операциями: добавление новой строки, удаление строки, редактирование имеющейся строки - PascalABC.NET
Нужно создать базу данных в паскале, с операциями: добавление новой строки, удаление строки, редактирование имеющей строки. Желательно с...

Строки. Даны строка S и подстрока S1.Удалить из строки S все вхождения строки S1 - Turbo Pascal
Даны строка S и подстрока S1.Удалить из строки S все вхождения строки S1.В строке S подсчитать кол-во вхождений строки S1.


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

Или воспользуйтесь поиском по форуму:
Nike0
6 / 6 / 0
Регистрация: 29.11.2009
Сообщений: 55
05.01.2011, 22:29  [ТС]     Строки в С #8
очень срочно нужна помощь, сделал без указателей, если кто-то чем-то может помочь, то напишите пожалуйста эту прогу с указателями, желательно второй функций, т.е. с теми же переменными (s,s1 и s2):
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
#include <stdio.h>
#pragma hdrstop
#include <conio.h>
#include <tchar.h>
#include <string.h>
#define N 80
#pragma argsused
 
/*bool abc(char *s, int bufsize, const char *s1, const char *s2)
{
    if(!*s1)
        return false;
    int targlen = strlen(s), oldlen = strlen(s1), newlen = strlen(s2);
    if(targlen - oldlen + newlen >= bufsize)
        return false;
    char *substr = strstr(s, s1);
    if(substr)
    {
        memmove(substr+newlen, substr+oldlen, strlen(substr)-oldlen+1);
        strncpy(substr, s2, newlen);
        return true;
    }
    return false;
} */
 
void Replace(char *s,char *s1,char *s2)
{
    int n;
    for (n = 0; s[n] != '\0'; n++)
    {
        int i;
        for (i=0; s[n+i] !='\0' && s1[i] !='\0'; i++)
            if (s[n+i] != s1[i])
                break;
        if (s1[i]=='\0')
        {
            int l2,dd,k;
            l2 = strlen(s2);
            dd = l2 - strlen(s1);
            if (dd < 0)
            {
                for (k=n; s[k-dd]!='\0'; k++)
                    s[k] = s[k-dd];
                s[k]='\0';
            }
            else
            {
                for (k=n; s[k]!='\0'; k++);
                for (; k != n; k--)
                     s[k+dd] = s[k];
            }
            for (k = 0; k < l2; k++)
                s[n+k] = s2[k];
        }
    }
    printf("\nNew string :\n%s",s);
}
 
int main()
{
    char s[N], s1[N], s2[N];
    clrscr();
    printf("Vvedite stroku s:\n");
    gets(s);
    printf("\nVvedite stroku s1:\n");
    gets(s1);
    printf("\nVvedite stroku s2:\n");
    gets(s2);
    Replace(s, s1, s2);
    getch();
    return 0;
}
закомментирвоанная булева функция abc. Это я набросал её с указателями, но вот что использовать её по-другому не получилось, разрулите как правильно плиз.
Yandex
Объявления
05.01.2011, 22:29     Строки в С
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru