Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
#1

Строки: нахождение символов и замена слов - C++

08.02.2013, 00:02. Просмотров 972. Ответов 16
Метки нет (Все метки)

Здравствуйте, дорогие форумчане.
---------------------------------------
Помогите, пожалуйста, с решением задачи.
Дана строка символов. Группы символов, разделённые одним или несколькими пробелами и не содержащие пробелы внутри себя, будем называть словами. Преобразовать строку, заменяя каждое вхождение слова "это" на слово "то".
http://www.cyberforum.ru/cpp-beginners/thread781670.html
---------------------------------------
За ранее благодарен.
Скрин с заданием прикрепил на всякий случай. Я просто пытаюсь на С+ написать, не выходит... На Паскале не могу додуматься, как делать. Кто-нибудь сможет написать программу, на С++, пожалуйста?
0
Миниатюры
Строки: нахождение символов и замена слов  
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.02.2013, 00:02
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Строки: нахождение символов и замена слов (C++):

Строки: нахождение символов и замена слов
Здравствуйте, дорогие форумчане. -----------------------------------...

Нахождение символов и замена их в строке
Программа не работает и выдает - " terminate called after throwing an instance...

Замена зарезервированных слов и символов в с++ на свои
Добрый вечер (у меня, по крайней мере вечер), прошу о помощи вроде бы в...

Строки: нахождение символов
Еще раз приветствую всех!:) ------------------------------- Помогите,...

Строки (замена символов)
У нас есть строка (пробел,точка,буква...) нужно заменить ===> на a на ...

16
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 00:05  [ТС] #2
Pascal
1
2
3
4
5
6
7
var s,sl: string;
    i,k: integer;
begin
write('s=');
readln(s);
s:=s+' ';
sl:='';
Вот только что на паскале смог, дальше никак... А программу надо на С++.
0
abit
272 / 271 / 83
Регистрация: 03.02.2013
Сообщений: 770
08.02.2013, 00:09 #3
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
Pascal
1
2
3
4
5
6
7
var s,sl: string;
    i,k: integer;
begin
write('s=');
readln(s);
s:=s+' ';
sl:='';
Вот только что на паскале смог, дальше никак... А программу надо на С++.
что-то вы и в паскале не смогли реализовать...
вас устроит решение с STL на C++?
там уже есть готовые алгоритмы для подобных дел или надо как можно проще?
0
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 00:10  [ТС] #4
Цитата Сообщение от abit Посмотреть сообщение
что-то вы и в паскале не смогли реализовать...
вас устроит решение с STL на C++?
там уже есть готовые алгоритмы для подобных дел или надо как можно проще?
Надо только на С++
0
abit
272 / 271 / 83
Регистрация: 03.02.2013
Сообщений: 770
08.02.2013, 00:15 #5
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
Надо только на С++
ну как бы STL давно часть C++, года с 98 чтоли... так что это будет именно в стиле C++, другое дело, что многие "эксперты" не знают что такое итераторы-контейнеры-библиотека<algorithm> и пишут C-подобный код, считая, что это С++, поэтому и спрашиваю устроит ли вас такое решение, если вы не знакомы с STL - вряд ли вы разберётесь что я напишу и лучше вашу задачу в раздел С отнести
1
Dekio
Фрилансер
Эксперт С++
5837 / 1218 / 499
Регистрация: 23.11.2010
Сообщений: 3,377
Записей в блоге: 1
08.02.2013, 00:15 #6
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <string>
#include <boost/algorithm/string/replace.hpp>
 
int main()
{
  std::string inputStr("this is sparta. this.. is.. SPARTA!!!");
  std::string searchWord("this");
  std::string resWord("that");
  boost::algorithm::ireplace_all(inputStr, searchWord, resWord);
  std::cout << inputStr << std::endl;
  return 0;
}
2
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 00:17  [ТС] #7
Цитата Сообщение от abit Посмотреть сообщение
ну как бы STL давно часть C++, года с 98 чтоли... так что это будет именно в стиле C++, другое дело, что многие "эксперты" не знают что такое итераторы-контейнеры-библиотека<algorithm> и пишут C-подобный код, считая, что это С++, поэтому и спрашиваю устроит ли вас такое решение, если вы не знакомы с STL - вряд ли вы разберётесь что я напишу и лучше вашу задачу в раздел С отнести
Ну я то разберусь, что вы написали... Я в с STL чуток знаком, так как нам в школе преподавали...

Добавлено через 58 секунд
Цитата Сообщение от Dekio Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <string>
#include <boost/algorithm/string/replace.hpp>
 
int main()
{
  std::string inputStr("this is sparta. this.. is.. SPARTA!!!");
  std::string searchWord("this");
  std::string resWord("that");
  boost::algorithm::ireplace_all(inputStr, searchWord, resWord);
  std::cout << inputStr << std::endl;
  return 0;
}
Спасибо)
0
abit
272 / 271 / 83
Регистрация: 03.02.2013
Сообщений: 770
08.02.2013, 00:19 #8
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
Ну я то разберусь, что вы написали... Я в с STL чуток знаком, так как нам в школе преподавали...
STL в школе? жесть) значит я старый динозавр, у нас дальше Borland C++ 3.1 не метались, но вижу решение уже вам дали, простите, что отнял время )

правда гляжу дали с бустом))) это жёсче, удачи в сборке )))
0
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 00:20  [ТС] #9
Цитата Сообщение от abit Посмотреть сообщение
STL в школе? жесть) значит я старый динозавр, у нас дальше Borland C++ 3.1 не метались, но вижу решение уже вам дали, простите, что отнял время )
Я в ФМШ учился, в Челябинске У нас там что только не было...
0
abit
272 / 271 / 83
Регистрация: 03.02.2013
Сообщений: 770
08.02.2013, 00:24 #10
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
Я в ФМШ учился, в Челябинске У нас там что только не было...
да я как бы переживал, что вы STL не осилите, а тут буст сходу... уже собрали? просто интересно )
0
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 01:29  [ТС] #11
Цитата Сообщение от abit Посмотреть сообщение
да я как бы переживал, что вы STL не осилите, а тут буст сходу... уже собрали? просто интересно )
Что именно собрали? Не понял вас...)

Добавлено через 6 минут
Я думал, что это просто алгоритм решения такой... Через string... Или я не прав? Если нет, то можно подробнее?
0
abit
272 / 271 / 83
Регистрация: 03.02.2013
Сообщений: 770
08.02.2013, 02:15 #12
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
Что именно собрали? Не понял вас...)

Добавлено через 6 минут
Я думал, что это просто алгоритм решения такой... Через string... Или я не прав? Если нет, то можно подробнее?
нет)))
там используется буст - http://ru.wikipedia.org/wiki/Boost
который вообще-то собрать достаточно проблематично как по времени, так и по другим не удобствам... и в С++ (вам же на С++ надо было решение?) в отличии от STL он не входит... в общем как разберётесь как собрать этот код, что вам дали (скомпилить и исполнить) - сразу поймёте
0
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 17:55  [ТС] #13
Цитата Сообщение от abit Посмотреть сообщение
нет)))
там используется буст - http://ru.wikipedia.org/wiki/Boost
который вообще-то собрать достаточно проблематично как по времени, так и по другим не удобствам... и в С++ (вам же на С++ надо было решение?) в отличии от STL он не входит... в общем как разберётесь как собрать этот код, что вам дали (скомпилить и исполнить) - сразу поймёте
А можете тогда на С++ решение написать, пожалуйста?

Добавлено через 38 секунд
Я просто с STL не так хорошо знаком...)

Добавлено через 3 часа 15 минут
Никто не знает решения этого задания на С++?

Добавлено через 3 часа 38 минут
АП.
0
abit
272 / 271 / 83
Регистрация: 03.02.2013
Сообщений: 770
08.02.2013, 19:10 #14
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
А можете тогда на С++ решение написать, пожалуйста?

Добавлено через 38 секунд
Я просто с STL не так хорошо знаком...)

Добавлено через 3 часа 15 минут
Никто не знает решения этого задания на С++?

Добавлено через 3 часа 38 минут
АП.
наверое самый простой способ - это воспользоваться функциями string::find и string::replace
но я простых путей не ищу )
только STL, только хардкор...

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
#include <string>
#include <vector>
#include <iostream>
 
using std::vector;  using std::cout;
using std::string;  using std::endl;
 
vector<string> split(const string& s)
{
    vector<string> ret;
    typedef string::size_type string_size;
    string_size i = 0;
    
    while (i != s.size()) {
        while (i != s.size() && isspace(s[i]))
            ++i;
        string_size j = i;
        while (j != s.size() && !isspace(s[j]))
            ++j;
        if (i != j) {
            ret.push_back(s.substr(i, j - i));
            i = j;
        }
 
    }
    return ret;
}
 
int main()
{
    string mystr = "это слово это а этоуже не слово это";
    string replfrom = "это";
    string replto = "то";
    string result("");
    string space("");
    vector<string> mywords=split(mystr);
    
    for (vector<string>::iterator it = mywords.begin(); it!=mywords.end(); ++it)
    {
        if (*it == replfrom) result += space+replto;
        else result += space + *it; 
        if (it==mywords.begin()) space = " ";
    }
    
    cout << result << endl;
    return 0;
}
1
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 21:18  [ТС] #15
Спасибо!)

Добавлено через 1 минуту
А есть еще способы решения этой задачи на С++? Интересно просто...
0
abit
272 / 271 / 83
Регистрация: 03.02.2013
Сообщений: 770
08.02.2013, 22:42 #16
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
Спасибо!)

Добавлено через 1 минуту
А есть еще способы решения этой задачи на С++? Интересно просто...
я же писал, можно воспользоваться стандартными функциями - std::string::find- вернёт позицию первой встретевшейся подстроки и следом std::string::replace - заменит эту подстроку на новую... единственное перед заменой - надо проверить что вокруг слова пробелы, либо начало строки, либо конец строки
помойму это самый простой и очевидный путь

сейчас попробую накидать

Добавлено через 40 минут
вот
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 <string>
#include <iostream>
 
using std::string;  using std::cout;
using std::endl;
 
int main()
{
    string mystr = "это слово это а этоуже не слово это";
    string replfrom = "это";
    string replto = "то";
   
    string::size_type i = 0;
    
    while (i<=mystr.size())
    {
        i = mystr.find(replfrom,i);
        if (i<mystr.size()) 
        {
            if  (((i==0)&&(isspace(mystr[i+replfrom.size()])) )  ||
                ((i+replfrom.size())>=mystr.size()) ||
                ((isspace(mystr[i+replfrom.size()]))&&(isspace(mystr[i-1])))) 
                mystr.replace(i,replfrom.size(),replto);
            ++i;
        }
    }
    
    cout << mystr << endl;
    return 0;
}
1
sanyachel9binsk
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
09.02.2013, 12:27  [ТС] #17
А теперь ещё интересней мне стало... А сколько способов решения на С++, есть у этой задачи?) Можно без решения... Просто цифрой... А можно с решениями... На ваше усмотрение)

Добавлено через 12 часов 36 минут
АП.
0
09.02.2013, 12:27
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.02.2013, 12:27
Привет! Вот еще темы с решениями:

Нахождение строки символов в исполняемом файле
Уважаемые программисты, помогите пожалуйста, не могу понять в чем ошибка....

Строки в стиле Си. Замена символов
Дана строка символов. Преобразовать данную строку, удалив из нее каждую пару...

Масивы и строки: поиск и замена слов в тексте
Помогите пожалуйста. Программа на массивы и строки, должна работать так: в...

Вывод строки в обратном порядке, замена символов
..может кто нибудь помочь?.. вот это вот надо сделать лёгким способом с...


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

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

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