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

Удаление подстроки из строки

12.03.2009, 01:18. Показов 24714. Ответов 7
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
теперь вот такая задача:
Удалить из строки все подстроки которые начинаются на < и оканчиваются на >.
попробовал написать,
вот что получилось:
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
#include "stdafx.h"
#include "stdio.h"
#include "conio.h"
#include "iostream.h"
#define MAX 300
 
 
void strrem(char *str, char *substr)//функция, реализующая удаление
{
    char *found;
    char *ptr;
    
    int length = strlen(substr);
    
    while(1) 
    {
        ptr = found = NULL;
        found = strstr(str, substr);
        if( found != NULL )
        {   
            ptr = &(found[length]);
            while(1)
            {
                *found = *ptr;
                if( *ptr == 0 )
                {
                    break;
                }
                found++;
                ptr++;
            }
        }
        else
        {
            return;
        }
    }
 
    return;
}
 
 
 
 
 
    int main()
{   
    int i,j,a,b,k,l,length;
    char text[300];
    printf("Enter string to process: ");
    gets(text);
    printf("Your string = '%s'\n", text);
    for (i = 0; i<MAX; i++)
    {
         if (text[i]=='<')
          {
              a=i;
              printf("number <='%d'\n", a);
                for (j = a; j<MAX; j++)
            {
                if (text[j]=='>')
            {   
                b=j;
                printf("number >='%d'\n", b);
                for(k=a; k<=b; k++)
                printf("%c", text[k]);//выводит то что нужно будет удалить
                strrem(text, text[k]);//здесь выдает ошибку
                break;
            }
                
                }
         }          
    }       
    
    
printf("\n%s\n",text );
    
    getch();
     return 0;
    
    }
компилятор выдает ошибку error C2664: 'strrem' : cannot convert parameter 2 from 'char' to 'char *'

подскажите плз, что неправильно?
заранее благодарен
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.03.2009, 01:18
Ответы с готовыми решениями:

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

Удаление подстроки из строки
Привет! Нужна ваша помощь. Требуется написать программу через С-строки: &quot;Написать программу,...

Удаление заданной подстроки из строки
Есть заданные слова, которые нужно удалить из строки. Пробовал так, но ошибка: #include...

Function - Delete(s,n,l). Purpose - удаление из строки s подстроки
Function - Delete(s,n,l). Purpose - удаление из строки s подстроки, начиная с позиции n, длиной l...

7
2816 / 1408 / 107
Регистрация: 07.03.2009
Сообщений: 4,446
12.03.2009, 01:24 2
ошибка в
C++
1
strrem(text, text[k]);
в прототипе у тебя указатели, поэтому возьми адрес... должно быть вот так

C++
1
strrem(text, &text[k]);
0
0 / 0 / 0
Регистрация: 11.03.2009
Сообщений: 17
12.03.2009, 01:28  [ТС] 3
если так, то прога копмилится, но ничего не удаляет..
0
2816 / 1408 / 107
Регистрация: 07.03.2009
Сообщений: 4,446
12.03.2009, 01:35 4
я не смотрел код удаления... лишь предпологал... сейчас посмотрю

Добавлено через 5 минут 4 секунды
я вообще не пойму.. зачем надо было так много писать?
0
0 / 0 / 0
Регистрация: 11.03.2009
Сообщений: 17
12.03.2009, 01:38  [ТС] 5
нуу, прогаю я хреново, поэтому смог тока так сделать..
0
2816 / 1408 / 107
Регистрация: 07.03.2009
Сообщений: 4,446
12.03.2009, 01:54 6
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
#include "stdafx.h"
#include "stdio.h"
#include "conio.h"
#include "iostream.h"
#define MAX 300
 
 
int main()
{   
    int i,j,a,b,k,length;
    char text[300];
  char txt[300];
 
    printf("Enter string to process: ");
    gets(text);
 
    printf("Your string = '%s'\n", text);
 
    for (i = 0; i<MAX; i++)
    {
         if (text[i]=='<')
          {
                a=i;
                printf("number <='%d'\n", a);
 
                  for (j = a; j<MAX; j++)
                  {
                      if (text[j]=='>')
                      {
                          b=j;
                          printf("number >='%d'\n", b);
                }
 
                  }
 
                }
  }
 
  for (i=0; i<a; i++)
      txt[i] = text[i];
 
  for (j=b+1; j<300; j++, ++i)
      txt[i] = text[j];
 
  printf("\n%s\n",txt );
 
    getch();
  return 0;
 
}
Добавлено через 1 минуту 4 секунды
если хочешь, можешь это вынести в отдельную функцию.. и уди лишнии переменные... и скопируй из txt в text

strcpy(text,txt);
2
0 / 0 / 0
Регистрация: 11.03.2009
Сообщений: 17
12.03.2009, 01:59  [ТС] 7
спс,
но так он удаляет только последнюю подстроку
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
12.03.2009, 03:10 8
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
 
#include <stdio.h>
#include <string.h>
 
#define MAXLINE  1000   /* максимальная длина строки */
 
void DeleteSubsLine(char *l, int left, int right);
void ClearLtGtSubs(char *s);
int Print(const char *s);
 
/* удаляет из строки подстроки с < до > */
main()
{
    char line[MAXLINE] = "abcd<efg>hабвг<деёж>:123.";
    
    ClearLtGtSubs(line);
    return 0;
}
 
/* Print:  выводит строку s с переводом */
int Print(const char *s)
{
    if (puts(s) < 0)
        return EOF;
    return 1;    
}
 
/* DeleteSubsLine:  удаляет из строки l подстроку,
                    начиная с left и заканчивая right */
void DeleteSubsLine(char *l, int left, int right)
{
    char *startp, *endp;
    
    if ((startp = strchr(l, left)) == NULL
     || (endp = strchr(l, right)) == NULL
     || endp-startp < 0)
        return;
    strcpy(startp, endp+1);
}
 
/* ClearLtGtSubs:  удаляет из s все подстроки с < до > */
void ClearLtGtSubs(char *s)
{
    int lt = '<', gt = '>';
    
    Print(s);
    while (strchr(s, lt) != NULL)
        DeleteSubsLine(s, lt, gt);
    Print(s);
}
1
12.03.2009, 03:10
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.03.2009, 03:10
Помогаю со студенческими работами здесь

Функция Delete(s,n,l) Назначение: удаление из строки s подстроки, начиная с позиции n, длиной l
Помогите пожалуйста составить функцию, не используя функции библиотек С, при помощи адресной...

Функция Delete(s,n,l) Назначение: удаление из строки s подстроки, начиная с позиции n, длиной l
помогите задачку написать.

Удаление подстроки
Доброго всем вечера. Извините конечно, но я завис на вот таком простом примере. Помогите плиз....

Удаление подстроки (С)
Ребят кто может помочь с удаление подстроки в строке, может у когото код завалялся. Строка:...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
В чем отличие между INNER JOIN и OUTER JOIN
bytestream 22.01.2025
В современных базах данных информация часто распределена между множеством взаимосвязанных таблиц, что делает операции объединения JOIN неотъемлемой частью работы с SQL. Эти операции позволяют. . .
Как сделать первую букву заглавной в JavaScript
bytestream 22.01.2025
JavaScript предоставляет разработчикам множество инструментов для эффективной работы с текстовыми данными. Одной из часто встречающихся задач при обработке строк является преобразование первой буквы. . .
Что такое Big O нотация и алгоритмическая сложность
bytestream 22.01.2025
Введение в алгоритмическую сложность В мире разработки программного обеспечения эффективность алгоритмов играет crucial роль в создании качественных приложений. Алгоритмическая сложность. . .
Как решать конфликты слияния (merge) в Git
bytestream 22.01.2025
Конфликты слияния в системе контроля версий Git возникают в ситуациях, когда две или более ветки разработки содержат несовместимые изменения в одних и тех же участках кода. Эти конфликты представляют. . .
Как использовать регулярные выражения
bytestream 22.01.2025
Регулярные выражения представляют собой мощный инструмент для работы с текстовыми данными, который позволяет осуществлять поиск, проверку и манипуляцию строками на основе определенных шаблонов. Этот. . .
Как выйти из Vim
bytestream 22.01.2025
Vim (Vi IMproved) представляет собой один из самых влиятельных текстовых редакторов в истории компьютерной индустрии, эволюционировавший из своего предшественника Vi, созданного Биллом Джоем в 1976. . .
NoSQL базы данных: что это такое и какие существуют
bytestream 22.01.2025
В современную эпоху цифровой трансформации объемы данных растут экспоненциально, создавая новые вызовы для традиционных систем управления базами данных. NoSQL (Not Only SQL) представляет собой. . .
Обновление исследования от команды MCM (январь 2025 г.)
Programma_Boinc 22.01.2025
Обновление исследования от команды MCM (январь 2025 г. ) Мы продолжаем изучать молекулярные сигнатуры, связанные с раком легких, с текущим фокусом на GCM1, факторе транскрипции, участвующем в. . .
Как работать с Kafka в Go (Golang)
bytestream 22.01.2025
Apache Kafka представляет собой распределенную платформу потоковой передачи данных, которая произвела революцию в области обработки событий и интеграции микросервисов. Эта система, изначально. . .
Как использовать RabbitMQ в Go (Golang)
bytestream 22.01.2025
RabbitMQ представляет собой надежный и широко используемый брокер сообщений, который играет ключевую роль в построении современных распределенных систем и микросервисной архитектуры. В основе работы. . .
Как преобразовать список списков в простой список в Python
bytestream 22.01.2025
При работе с Python разработчики часто сталкиваются с необходимостью обработки сложных структур данных, среди которых особое место занимают вложенные списки. Эти структуры представляют собой списки,. . .
Что такое GUID / UUID и как их создать
bytestream 22.01.2025
В мире разработки программного обеспечения существует постоянная потребность в уникальной идентификации объектов, записей и ресурсов. Эта задача становится особенно актуальной в распределенных. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru