Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
2 / 2 / 0
Регистрация: 09.07.2012
Сообщений: 14
1

Удвоить все найденные вхождения строки в текст

16.07.2012, 11:48. Просмотров 858. Ответов 5
Метки нет (Все метки)

c++ visual
Задание: дан текст и строка. удвойте все найденные вхождения строки.
насколько я понимаю, если ввести текст "мама мыла раму" и строку"мыла", то должно получиться "мама мыламыла раму".
прочитала тут про функцию Pos, пытаюсь ее применить, но компилятор ругается. может эта функция только для билдера? помогите решить задачку хоть как нибудь.
доп.условие: ввод и вывод русского текста

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
#include<stdio.h>
#include<windows.h>
#include<string.h>
#include<conio.h>
 
 
int main()
{
    SetConsoleOutputCP(1251);
    char text[256], text2[256], str[64];
    int i, j;
    printf("введите текст:\n");
    fflush(stdin);
    gets(text);
    OemToChar(text, text);
    printf("введите строку:\n");
    fflush(stdin);
    gets(str);
    OemToChar(str, str);
    if(strstr(text, str)!=NULL){
    for(i = 0; i < text.Pos(str); i++)
        text2[i]=text[i];
    for(i = text.Pos(str), j=0; j < strlen(str); i++, j++)
        text2[i]=str[j];
    for(i = text.Pos(str)+strlen(str), j=text.Pos(str); j < strlen(text); i++, j++)
        text2[i]=text[j];
    }
    printf("результат:%s\n", text);
    system("pause");
    return 0;}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.07.2012, 11:48
Ответы с готовыми решениями:

Строки: вывести все вхождения заданного имени в текст
Задание: Вводят имя и текст, вывести все вхождения имени в текст (имя + 5 символов до и 5...

Найти все вхождения строки P в текст T, используя наивный алгоритм поиска
Только начал изучать язык С++, не могу никак реализовать: даны строки P и T. Найти все вхождения...

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

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

5
575 / 253 / 18
Регистрация: 29.11.2010
Сообщений: 868
16.07.2012, 12:13 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
#include <iostream>
#include<string>
 
using namespace std;
 
int main()
{
    string text,str;
    cout<<"ўўҐ¤ЁвҐ ⥪бв:\n";
    getline(cin,text);
    cout<<"ўўҐ¤ЁвҐ бва®Єг:\n";
    getline(cin,str);
    size_t n=text.find(str);
    if(n!=string::npos)
    {
         text.insert(n,str);
         cout<<"१г«мв*в:%s\n"<<text;
    }
    else
        cout<<"ЌҐв в*Є®© бва®ЄЁ\n";
    system("pause");
    return 0;
}
}
1
59 / 59 / 8
Регистрация: 29.06.2012
Сообщений: 188
16.07.2012, 12:18 3
Что Вы хотите от функции Pos ?
Как я понимаю аналог функции Pos - strstr
0
Модератор
Эксперт Python
26653 / 13900 / 2643
Регистрация: 12.02.2012
Сообщений: 22,783
Записей в блоге: 1
16.07.2012, 12:21 4
Вот "детское" (но работающее) решение:

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
#include <iostream.h>
#include <string.h>
 
char * DupWord(char *stri, char *word)
{
    int i,j,k,n,l;
    char *curr;
 
    n=strlen(stri);
    l=strlen(word);
    
    char *wd=new char[l+1];
    char *Res=new char[n*2+1];
 
    for (i=0; i<n*2+1; i++) Res[i]=0;
 
    i=0;
    k=0;
    curr=stri;
 
    while(1)
    {
        // áåðåì l ñèìâîëîâ ñ i-é ïîçèöèè
        for (j=0; j<l; j++) wd[j]=stri[i+j];
        wd[l]=0;
        // ïðîâåðÿåì, íå íàøëè ëè ñëîâî?
        if (strcmp(wd,word) == 0)
        {
            // êðîïèðóåì â âûõ. ñòðîêó äâàæäû
            for (j=0; j<l; j++) Res[k++]=word[j];
            for (j=0; j<l; j++) Res[k++]=word[j];
            i=i+l-1;
        }
        else
        {   // êîïèðóåì îäèí ñèìâîë
            Res[k++]=stri[i];
        }
        i++;
        if ((n-i) < l)
        {   // êîïèðóåì îñòàòîê äî êîíöà ñòðîêè
            for (j=0; j<n-i; j++) Res[k++]=stri[j];
            Res[k++]=0;
            break;
        }
    }
 
    delete [] wd;
    return Res;
 
}
 
int main(int argc, char* argv[])
{
        char *S="To be or not to be";
        char *R=DupWord(S,"be");
 
        cout << R << endl;
 
        delete [] R;
 
        return 0;
}
0
Заблокирован
Автор FAQ
16.07.2012, 14:24 5
prettynetty, как таковой функции Pos в языке не существует её надо писать. Предагаю на рассмотрение не очень сложный код на Си как раз с самописной функцией Pos
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
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
 
//Ôóíêöèÿ âîçâðàùàåò ïîçèöèþ 1-ãî âõîæäåíèÿ sub â str
//Åñëè sub îòñóòñâóåò â str âîçâðàùàåìîå çíà÷åíèå -1
int Pos(char * str, char * sub); 
 
//"ìàìà ìûëà ðàìó ðàìó ìûëà ìàìà"
int main()
{
    int pos = -1;//Áóäåò ñîäåðæàòü â ñåáå ïîçèöèþ ïîäñòðîêè â òåêñòå
    system("chcp 1251");//ðóññèôèêàöèÿ
    char text[1024] = {0};//áóäåò ñîäåðæàòü â ñåáå ââîäèìûé òåêñò
    char buf [1024] = {0};//áóôôåð äëÿ èñõîäíîãî òåêñòà
    char str [64]   = {0};
    printf("Enter text (less than 1024 chars) : ");
    scanf("%[^\n]",text);getchar();//Ââîäèì òåêñò
    printf("Enter string (less than 64 chars) : ");
    scanf("%[^\n]",str);getchar();//Ââîäèì ñòðîêó
    int sLen = strlen(str);//Óçíà¸ì äëèííó ïïîäñòðîêè 
    pos = Pos(text, str);//Èùåì ïîäñòðîêó â òåêñòå
    while(-1 < pos)
    {
        //Êîïèðóåì â áóôåð ÷àñòü ñòðîêè ïîñëå str
        strcpy(buf, text + pos + sLen);
        text[pos + sLen] = '\0';//Îòáðàñûâàåì îñòàâøóþñÿ ÷àñòü òåêñòà
        strcat(text, str);//Äîáàâëÿåì ê ñòðîêå str (äóáèëèðóåì å¸)
        strcat(text, buf);//Äîáàâëÿåì ê ñòðîêå îòáðîøåííóþ ÷àñòü
        //Èùåì ñëåäóþùåå çà pos âõîæäåíèå str â òåêñò
        pos = pos + 2*sLen;
        if(-1 < Pos(&text[pos], str))
            pos = pos + Pos(&text[pos], str);
        else
            pos = -1;
    }
    printf("Text after doubling : %s\n", text);
    system("pause");
    return 0;
}
 
int Pos(char * str, char * sub)
{
    int pos = -1;
    char * buf = NULL;//Óêàçàòåëü íà ñòðîêó
    if(str != NULL && sub != NULL)
    {
        buf = strstr(str,sub);
        if(buf != NULL)
            pos = strlen(str) - strlen(buf);
    }
    return pos;
}
1
Миниатюры
Удвоить все найденные вхождения строки в текст  
2 / 2 / 0
Регистрация: 09.07.2012
Сообщений: 14
16.07.2012, 16:21  [ТС] 6
-=ЮрА=-, спасибо. очень помогли

Добавлено через 44 секунды
defer,
Catstail,
спасибо
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.07.2012, 16:21

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Строка: Удалить из строки S1 все вхождения строки S2
Удалить из S1 все вхождения S2.

Стек. Выведите все вхождения символов указанного набора в текст в обратном порядке
Дан текст, состоящий из заглавных и строчных английских букв, символов ! ; ? . , - : ; ) ( ' &quot;...

Найти все вхождения строки s в t
Требуется написать программу, которая выводить на экран идексы всех вхождений строки s в строку t:...

Удалить все вхождения символов из строки
как удалить вхождение всех точек в строку, стандартными средствами, без цикла написанного вручную....


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

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