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

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

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

Author24 — интернет-сервис помощи студентам
Здравствуйте, дорогие форумчане.
---------------------------------------
Помогите, пожалуйста, с решением задачи.
Дана строка символов. Группы символов, разделённые одним или несколькими пробелами и не содержащие пробелы внутри себя, будем называть словами. Преобразовать строку, заменяя каждое вхождение слова "это" на слово "то".
---------------------------------------
За ранее благодарен.
Скрин с заданием прикрепил на всякий случай. Я просто пытаюсь на С+ написать, не выходит... На Паскале не могу додуматься, как делать. Кто-нибудь сможет написать программу, на С++, пожалуйста?
Миниатюры
Строки: нахождение символов и замена слов  
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.02.2013, 00:02
Ответы с готовыми решениями:

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

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

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

Нахождение в файле слов с длиной K символов
программа : Написать программу нахождения в строковом файле слов с длиной K символов и переписать в...

16
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
390 / 365 / 111
Регистрация: 03.02.2013
Сообщений: 1,120
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
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 00:10  [ТС] 4
Цитата Сообщение от abit Посмотреть сообщение
что-то вы и в паскале не смогли реализовать...
вас устроит решение с STL на C++?
там уже есть готовые алгоритмы для подобных дел или надо как можно проще?
Надо только на С++
0
390 / 365 / 111
Регистрация: 03.02.2013
Сообщений: 1,120
08.02.2013, 00:15 5
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
Надо только на С++
ну как бы STL давно часть C++, года с 98 чтоли... так что это будет именно в стиле C++, другое дело, что многие "эксперты" не знают что такое итераторы-контейнеры-библиотека<algorithm> и пишут C-подобный код, считая, что это С++, поэтому и спрашиваю устроит ли вас такое решение, если вы не знакомы с STL - вряд ли вы разберётесь что я напишу и лучше вашу задачу в раздел С отнести
1
Фрилансер
Эксперт С++
5845 / 1226 / 499
Регистрация: 23.11.2010
Сообщений: 3,375
Записей в блоге: 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
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
390 / 365 / 111
Регистрация: 03.02.2013
Сообщений: 1,120
08.02.2013, 00:19 8
Цитата Сообщение от sanyachel9binsk Посмотреть сообщение
Ну я то разберусь, что вы написали... Я в с STL чуток знаком, так как нам в школе преподавали...
STL в школе? жесть) значит я старый динозавр, у нас дальше Borland C++ 3.1 не метались, но вижу решение уже вам дали, простите, что отнял время )

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

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

Добавлено через 6 минут
Я думал, что это просто алгоритм решения такой... Через string... Или я не прав? Если нет, то можно подробнее?
нет)))
там используется буст - http://ru.wikipedia.org/wiki/Boost
который вообще-то собрать достаточно проблематично как по времени, так и по другим не удобствам... и в С++ (вам же на С++ надо было решение?) в отличии от STL он не входит... в общем как разберётесь как собрать этот код, что вам дали (скомпилить и исполнить) - сразу поймёте
0
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
390 / 365 / 111
Регистрация: 03.02.2013
Сообщений: 1,120
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
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
08.02.2013, 21:18  [ТС] 15
Спасибо!)

Добавлено через 1 минуту
А есть еще способы решения этой задачи на С++? Интересно просто...
0
390 / 365 / 111
Регистрация: 03.02.2013
Сообщений: 1,120
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
1 / 1 / 2
Регистрация: 27.10.2012
Сообщений: 209
09.02.2013, 12:27  [ТС] 17
А теперь ещё интересней мне стало... А сколько способов решения на С++, есть у этой задачи?) Можно без решения... Просто цифрой... А можно с решениями... На ваше усмотрение)

Добавлено через 12 часов 36 минут
АП.
0
09.02.2013, 12:27
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
09.02.2013, 12:27
Помогаю со студенческими работами здесь

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

Стек: нахождение количества слов, состоящих из более чем 3-х символов
Проблема в организации цикла для нахождения кол-ва слов, состоящих из более чем 3-х символов....

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

Замена одних символов или слов в тексте на другие
Привет народ, помогите пожалуйста. Нужно решить задачу по поиску слова (символов) в тексте и замене...


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

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru