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

Дана строка. Удалить из нее самую длинную подстроку, что состоит из цифр

23.02.2014, 19:46. Показов 1345. Ответов 3
Метки нет (Все метки)

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
#include <iostream>
using namespace std;
 
int main()
{
    char s[1000];
    int l=0, a[1000];
    cout << "stroka= ";
    cin.getline(s, 1000);
    for (int i = 0,j=0; i<strlen(s); i++)
    {
        if (s[i] >= '0' && s[i] <= '9')
        {
            l++;
        }
        else
        {
            if (l>0)
            {
                a[i] = l; 
                l = 0;
            }
            l = 0;
        }
    }
    int max = 0,k;
    for (int i = 0; i < 1000; i++)
    {
    if (max<a[i])
        {
            max = a[i];
            k = i-max;
        }
    }
    
    char news[1000];
    
    for (int i = 0,j=0; i < strlen(s); i++)
    {
        if (i<k && i>max+k-1)
        {
            news[j]=s[i];
            j++;
            news[j] = '0';
        }
        
    }
    
    cout << "new stroka = ";
    cout << news;
    system("pause");
    return 0;
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.02.2014, 19:46
Ответы с готовыми решениями:

Дана строка цифр, удалить из нее цифры 3 и 6
,,,,,,,

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

Дана строка. Удалить из нее все последовательности цифр начинающихся с 1
Вызвала затруднения. Надеюсь на помощь. Дана строка. Удалить из нее все последовательности цифр...

Удалить из строки самую длинную подстроку, состоящую из повторяющегося символа
Здравствуйте! Подскажите как можно решить данную задачку: Разработать программу, которая для...

3
272 / 266 / 146
Регистрация: 02.08.2012
Сообщений: 609
23.02.2014, 20:41 2
Halkidik, удалить длинную подстроку только из цифр или если имеется хоть одна цифра?
1
0 / 0 / 0
Регистрация: 16.12.2013
Сообщений: 6
23.02.2014, 23:13  [ТС] 3
самую длинную строку из цифр ,даже если она состоит из одного элемента, допустим если введена строка (klompa7hbhb) то нужно удалить 7

Добавлено через 3 минуты
я еще так попытался , но тоже фигня
#include <iostream>
#include <conio.h>
using namespace std;

int main()
{
char s[1000];
int l=0, a[1000];
cout << "stroka= ";
cin.getline(s, 1000);
for (int i = 0,j=0; i<strlen(s); i++)
{
if (s[i] >= '0' && s[i] <= '9')
{
l++;
}
else
{
if (l>0)
{
a[i] = l;
l = 0;
}
l = 0;
}
}
int max = 0,k;
for (int i = 0; i < 1000; i++)
{
if (max<a[i])
{
max = a[i];
k = i-max;
}
}
cout << "new stroka = ";
cout << strcpy(&s[k], &s[k + max]);
getch();

}

Добавлено через 3 минуты
GuGo1991, я уже голову сломал.......
0
272 / 266 / 146
Регистрация: 02.08.2012
Сообщений: 609
24.02.2014, 03:34 4
Halkidik, так я не понял надо только числа удалить или всё слово?
В общем, следующий код находит из строки самое длинное слово (первое), которое содержит цифры,
удаляет эти цифры и печатает это слово без цифр. Исключая при этом некоторые символы,
такие как запятая, точка и т. д. Так что, в случае - first,second, запятая сыграет роль пробела.

Кликните здесь для просмотра всего текста
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
#include <iostream>
#include <string>
#include <sstream>
 
bool check_func(char ch)
{
    if(ch == ' ' || ch == ',' || ch == '.' ||
       ch == '!' || ch == '?' || ch == ';' ||
       ch == ':' || ch == '(' || ch == ')' ||
       ch == '"' || ch == '<' || ch == '>')
        return true;
    return false;
}
 
bool check_num(std::string s)
{
    int index = 0;
    while(s[index])
    {
        for(int i = 0; i < 10; i++)
        {
            if((char)(((int)'0') + i) == s[index])
                return true;
        }
        index++;
    }
    return false;
}
 
int main()
{
    std::string s, temp;
    std::string* str;
    int index = 0, counter = 0, size;
    std::cout << "Enter string: ";
    getline(std::cin, s);
    
    while(s[index])
    {
        if(!check_func(s[index]))
        {                        
            while(check_func(s[index]))
            {
                index++;
            }
            counter++; 
        }
        index++; 
    }
    
    size = counter + 1; 
    str = new std::string[size];
    counter = 0;
    index = 0;
    
    while(s[index])
    {
        if(!check_func(s[index]))
        {
            temp += s[index]; 
            if(!s[index + 1])
            {
                str[counter] = temp; 
                counter++; 
            }              
        }
        else
        {
            if(temp != "") 
            {
                str[counter] = temp;
                temp.clear();
                counter++;
            }
        }
        index++;
    }
    
    size = counter;
    int max = 0, max_index = size;
    
    for(int i = 0; i < size; i++)
    {
        if(max < str[i].size() && check_num(str[i]))
        {
            max = str[i].size();
            max_index = i;
        }
    }
    
    if(max_index < size)
    {
        index = 0;
        temp = str[max_index];
        while(temp[index])
        {
            switch(temp[index])
            {
                case '0':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '1':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '2':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '3':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '4':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '5':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '6':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '7':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '8':
                    temp.replace(index, 1, "");
                    index--;
                    break;
                case '9':
                    temp.replace(index, 1, "");
                    index--;
                    break;
            }
            index++;
        }
        std::cout << temp << "\n";
    }
    delete [] str;
    
    system("pause");
    return 0;
}
1
24.02.2014, 03:34
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.02.2014, 03:34
Помогаю со студенческими работами здесь

Дана символьная строка.подсчитать самую длинную последовательность
подряд идущих букв а.

Строка: найти самую длинную группу цифр
Дан текст, каждый символ которого может быть малой буквой, цифрой или одним из знаков +, -, *....

Дана строка. Подсчитать самую длинную последовательность подряд идущих букв а.
Дана строка. Подсчитать самую длинную последовательность подряд идущих букв а.

Дана строка. Подсчитать самую длинную последовательность подряд идущих букв а
Дана строка. Подсчитать самую длинную последовательность подряд идущих букв а.

Дана строка. Подсчитать самую длинную последовательность подряд идущих букв а
эта же тока подряд идущих букв а плиз помогите

Дана строка. Подсчитать самую длинную последовательность подряд идущих букв а
Дана строка. Подсчитать самую длинную последовательность подряд идущих букв а.


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
Полезные поделки на Arduino, которые можно сделать самому
raxper 06.01.2025
Arduino как платформа для творчества Arduino представляет собой удивительную платформу для технического творчества, которая открывает безграничные возможности для создания уникальных проектов. Эта. . .
Подборка решений задач на Python
IT_Exp 06.01.2025
Целью данной подборки является предоставление возможности ознакомиться с различными задачами и их решениями на Python, что может быть полезно как для начинающих, так и для опытных программистов. . . .
С чего начать программировать микроконтроллер­­ы
raxper 06.01.2025
Введение в мир микроконтроллеров Микроконтроллеры стали неотъемлемой частью современного мира, окружая нас повсюду: от простых бытовых приборов до сложных промышленных систем. Эти маленькие. . .
Из чего собрать игровой компьютер
inter-admin 06.01.2025
Сборка игрового компьютера требует особого внимания к выбору комплектующих и их совместимости. Правильно собранный игровой ПК не только обеспечивает комфортный геймплей в современных играх, но и. . .
Обновление сайта www.historian.b­y
Reglage 05.01.2025
Обещал подвести итоги 2024 года для сайта. Однако начну с того, что изменилось за неделю. Добавил краткий урок по последовательности действий при анализе вредоносных файлов и значительно улучшил урок. . .
Как использовать GraphQL в C# с HotChocolate
Programming 05.01.2025
GraphQL — это современный подход к разработке API, который позволяет клиентам запрашивать только те данные, которые им необходимы. Это делает взаимодействие с API более гибким и эффективным по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru