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

Написать программу, которая считывает с клавиатуры текст и выводит на экран толь¬ко предложения, состоящие из заданного количества слов. - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Определитель матрицы. http://www.cyberforum.ru/cpp-beginners/thread522297.html
Всем привет..прошу помощи в программе. сам код есть...в нее нужно включить определитель матрицы, я с ним запуталась, вот код программы: // t1.cpp: определяет точку входа для консольного приложения....
C++ Массив струкур Здравствуйте! В универе задали написать лабу, такое вот задание: Определить структурированный тип и набор функций для работы с таблицей записей, реализованной в массиве структур. В перечень функций... http://www.cyberforum.ru/cpp-beginners/thread522296.html
C++ поиск в глубину
Дали задание реализовать поиск в глубину.Пробую релизовать по e-maxx http://e-maxx.ru/algo/dfsно не получается. vector<char> used; int n; vector <vector <int> > g; void dfs (int v) { used =...
Бинарное возведение матрицы в степень C++
Подскажите, пожалуйста, как оно реализуется, причем, пишут, что если матрица размером n*n, и нужно возвести ее в степень k - сложность O( n^3 log k ). O( n^3 * k ) написать не сложно, а вот как тут...
C++ найти количество слов, которые имеют последнюю букву первого слова. http://www.cyberforum.ru/cpp-beginners/thread522274.html
добрый день помогите пожалуйста с задачей. надо найти количество слов, которые имеют последнюю букву первого слова. заранее благогдарен
C++ Вычислить объемы тетрайда, гексаэдра и октаэдры, если длины ребер многогранников одинаковы и равны 3,55 см. Вычислить объемы тетрайда, гексаэдра и октаэдры, если длины ребер многогранников одинаковы и равны 3,55 см. подробнее

Показать сообщение отдельно
ForEveR
В астрале
Эксперт С++
7978 / 4737 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
19.03.2012, 16:35
1.
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 <iostream>
#include <boost/algorithm/string.hpp>
#include <string>
#include <vector>
#include <algorithm>
#include <iterator>
 
int main()
{
   std::string s = "Hello and what. Is it now true? Such good thing! What is it?!";
   const size_t words_count = 3;
   const std::string sent_delims = ".?!";
   const std::string word_delims = " ,:";
   std::vector<std::string> sentences;
   boost::split(sentences, s, boost::is_any_of(sent_delims), boost::token_compress_on);
   std::transform(sentences.begin(), sentences.end(), sentences.begin(), [](const std::string& val)
   {
      return boost::trim_copy(val);
   });
   std::vector<std::string> right_sentences;
   std::copy_if(sentences.begin(), sentences.end(), std::back_inserter(right_sentences),
   [words_count, word_delims](const std::string& value) -> bool
   {
      std::vector<std::string> words;
      boost::split(words, value, boost::is_any_of(word_delims), boost::token_compress_on);
      return words.size() == words_count;
   });
   std::copy(right_sentences.begin(), right_sentences.end(), 
   std::ostream_iterator<std::string>(std::cout, "\n"));
}
http://liveworkspace.org/code/6598b9...ab39694b20482e

Добавлено через 4 минуты
2.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
#include <string>
#include <algorithm>
 
int main()
{
   std::string s = "Hello and what. Is it now true? Such good thing! What is it?!";
   char symbol = 'T';
   std::string::iterator iter = std::find(s.begin(), s.end(), symbol);
   if (iter == s.end())
   {
      std::cout << "No symbol " << symbol << " in string." << std::endl;
   }
   else
   {
      s.erase(iter);
   }
   s.insert(s.begin(), 1, symbol);
   std::cout << "string: " << s << " symbol: " << symbol << std::endl;
}
http://liveworkspace.org/code/d06361...09ba213f3a6cfb
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru