Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
hospik
1 / 1 / 0
Регистрация: 21.11.2011
Сообщений: 77
#1

Разработать алгоритм и программу для удаления из введенного текста слов, которые начинаются и заканчиваются одним и тем же символом - C++

20.05.2012, 15:41. Просмотров 723. Ответов 5
Метки нет (Все метки)

Разработать алгоритм и программу для удаления из введенного текста слов, которые начинаются и заканчиваются одним и тем же символом.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.05.2012, 15:41
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Разработать алгоритм и программу для удаления из введенного текста слов, которые начинаются и заканчиваются одним и тем же символом (C++):

Разработать алгоритм и программу для удаления из введенного текста слов, которые начинаются и заканчиваются одним и тем же символом. - C++
1. Разработать алгоритм и программу для удаления из введенного текста слов, которые начинаются и заканчиваются одним и тем же символом.

Разработать алгоритм и программу для определения количества слов в введенном тексте, которые начинаются на буквой "А" - C++
Разработать алгоритм и программу для определения количества слов в введенном тексте, которые начинаются буквой "А". Считать, что слова в...

Разработать программу находит слова, которые начинаются и заканчиваются одной - C++
Разработать программу, которая вводит текст, находит в нем слова, которые начинаются и заканчиваются одной и той же буквой, и заключает их...

Разработать алгоритм и программу для удаления в тексте всех слов, содержащих символы-цифры - C++
Разработать алгоритм и программу для удаления в тексте всех слов, содержащих символы-цифры

Разработать алгоритм и программу для удаления в тексте всех слов, содержащих символы-цифры. - C++
hellp me!!! 1. Разработать алгоритм и программу для удаления в тексте всех слов, содержащих символы-цифры.

Разработать алгоритм и программу для удаления в заданном тексте части текста, взятого в скобки (вместе со скобками) - C++
Разработать алгоритм и программу для удаления в заданном тексте части текста, взятого в скобки (вместе со скобками).Помогите плиз для...

5
talis
792 / 544 / 37
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
26.05.2012, 19:33 #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
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
#include <iostream>
#include <sstream>
#include <string>
#include <algorithm>
#include <iterator>
 
typedef std::istream_iterator<std::wstring, wchar_t, std::char_traits<wchar_t>> wistream_iterator;
typedef std::ostream_iterator<std::wstring, wchar_t, std::char_traits<wchar_t>> wostream_iterator;
 
// К сожалению, такой прелести в STL нет :-(
template <class InputIterator, class OutputIterator, class Predicate>
OutputIterator copy_if
(
    InputIterator first,
    InputIterator last,
    OutputIterator result,
    Predicate pred 
)
{
    while( first != last )
    {
        if( pred( *first ) )
            *result++ = *first++;
    }
 
    return result;
}
 
int main( )
{
    std::setlocale( LC_ALL, "ru_RU.UTF8" );
    
    // читаем строку
    std::wstring input;
 
    std::wcout << '>';
    std::getline( std::wcin, input );
 
    std::wistringstream input_stream( input, std::wistringstream::in );
 
    // копируем из неё слова на вывод
    std::copy_if( wistream_iterator ( input_stream ), wistream_iterator(), wostream_iterator( std::wcout, L" " ),
               []( const std::wstring &str )
               {
                  // копируем только если буква в начале слова не равна букве в конце слова
                  return towlower( 
                           *( std::find_if( str.begin(), str.end(), // игнорируем все знаки препинания с начала
                               []( const wchar_t &ch )
                                { 
                                    return iswalpha( ch ); 
                                } 
                                ) 
                            ) 
                         )
                         !=                  
                         towlower( 
                            *( std::find_if( str.rbegin(), str.rend(), // игнорируем все знаки препинания с конца
                               []( const wchar_t &ch )
                                { 
                                    return iswalpha( ch ); 
                                } 
                                ) 
                            )
                         );
               }
            );
 
    return 0;
}
1
igorrr37
1648 / 1276 / 133
Регистрация: 21.12.2010
Сообщений: 1,932
Записей в блоге: 7
26.05.2012, 20:14 #3
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
#include <iostream>
#include <fstream>
#include <string>
#include <iterator>
#include <algorithm>
#include <cctype>
#include <sstream>
 
int main()
{
    std::fstream ifs("1.txt", std::ios::in), ofs("2.txt", std::ios::out);
    if(ifs.is_open() && ofs.is_open())
    {
        std::string s((std::istreambuf_iterator<char>(ifs)), std::istreambuf_iterator<char>()), sRepl;
        std::replace_copy_if(s.begin(), s.end(), std::back_inserter(sRepl), [](char c){return !std::isalpha(c);}, ' ');
        std::istringstream iss(sRepl);
        std::string::size_type ind, wSize;
        while(iss >> sRepl)
        {
            wSize = sRepl.size();
            if(sRepl.at(0) == sRepl.at(wSize - 1) && (ind = s.find(sRepl)) != std::string::npos)
            {
                s.erase(ind, wSize);
            }
        }
        ofs << s;
    }
    else std::cerr << "Unable to open file(s)\n";
    ifs.close();
    ofs.close();
    return 0;
}
1
easybudda
Модератор
Эксперт CЭксперт С++
9693 / 5643 / 962
Регистрация: 25.07.2009
Сообщений: 10,847
26.05.2012, 20:37 #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
#include <iostream>
#include <string>
#include <sstream>
#include <algorithm>
#include <iterator>
 
class NoSameFirstLast {
    std::ostream & ost;
public:
    NoSameFirstLast(std::ostream & _ost) : ost(_ost) {}
    void operator () (const std::string & wrd) {
        if ( *wrd.begin() != *wrd.rbegin() )
            ost << wrd << ' ';
    }
};
 
int main() {
    std::string str;
    
    while ( std::cout << "String: " && std::getline(std::cin, str) && ! str.empty() ) {
        std::istringstream ist(str);
        std::cout << "Result: ";
        std::for_each(std::istream_iterator<std::string>(ist), std::istream_iterator<std::string>(), NoSameFirstLast(std::cout));
        std::cout << std::endl;
    }
    
    return 0;
}
1
isaak
103 / 40 / 9
Регистрация: 17.10.2010
Сообщений: 670
26.05.2012, 20:50 #5
Покажите пожалуйста на конкретном примере как она работает. Заранее огромное спасибо.

Добавлено через 1 минуту
Спасибо все разобрался!
0
zarko97
278 / 38 / 0
Регистрация: 11.10.2015
Сообщений: 405
15.03.2017, 19:19 #6
C++
1
2
3
4
5
6
7
8
9
10
void remove(std::string& some)
{
    std::stringstream ss{ some };
    std::string cur;
    while (ss >> cur) 
    {
        if (*cur.begin() != *cur.rbegin())
            std::cout << cur << ' ';
    }
}
0
15.03.2017, 19:19
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.03.2017, 19:19
Привет! Вот еще темы с ответами:

Выписать из текста слова, которые начинаются и заканчиваются цифрой - C++
Здравствуйте,подскажите пожалуйста,как описать,что бы тексте искалась цифра,потому что,не приходит на ум,как это описать Вот такое...

Найти количество слов в тексте, которые начинаются и заканчиваются одинаковыми буквами - C++
#include&lt;iostream&gt; #include&lt;string&gt; using namespace std; int main() { int g(0), m, k; string text; int sum = 0; cout &lt;&lt;...

Среди слов вывести в начале те, которые начинаются и заканчиваются одной буквой - C++
Среди слов вывести в начале те, которые начинаются и заканчиваются одной буквой, затем остальные. Нашел только программу, которая наоборот...

Определить количество слов, которые начинаются и заканчиваются одной и той же буквой - C++
Дана строка, состоящая из слов, разделенных пробелом. Определить количество слов, которые начинаются и заканчиваются одной и той же буквой....


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

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

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