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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 48, средняя оценка - 4.90
vendeme
-32 / 3 / 3
Регистрация: 22.06.2011
Сообщений: 88
#1

[STL] Работа со std::string - C++

24.08.2012, 17:47. Просмотров 6202. Ответов 52
Метки нет (Все метки)

Привет, форум.

Подскажите, как можно грамотно скопировать "слово" из строки, с указанием начала и конца позиций.
Например:
C++
1
2
string str = "My name is Vendetta";
string str name;
нужно грамотно, методом STL, скопировать буквы с 12 по 19. То-есть, слово Vendetta присвоить к name.
Заранее спасибо, может чуть позже ещё будут вопросы на эту тему.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.08.2012, 17:47
Здравствуйте! Я подобрал для вас темы с ответами на вопрос [STL] Работа со std::string (C++):

ошибка error: cannot convert 'std::string {aka std::basic_string<char>}' to 'std::string* {aka std::basic_stri - C++
на вод поступают 2 строки типа string. определить количество вхождений строки 2 в строку 1 ошибка error: cannot convert 'std::string {aka...

STL std::set, std::pair, std::make_pair - C++
Я не знаю как описать тему в двух словах, поэтому не обращайте внимание на название темы. Собственно перейдем к нашим баранам: есть...

запрошено преобразование от ‘const std::string*’ к нескалярному типу ‘std::string’ - C++
private: std::string firstName; }; std::string ClientData::getFirstName() const{ return firstName; } Дает в итоге...

Стандартный поток и STL (std::copy to std::cout) - C++
#include &lt;iostream&gt; #include &lt;sstream&gt; #include &lt;algorithm&gt; #include &lt;functional&gt; #include &lt;string&gt; using namespace std; ...

Работа с классом std::string - C++
Доброго времени суток! Помогите, пожалуйста, с задачей! Никак решить не могу!=( Дан обычный текст на латинице в строке std::string....

На основе исходного std::vector<std::string> содержащего числа, создать std::vector<int> с этими же числами - C++
подскажите есть вот такая задача. Есть список . Создать второй список, в котором будут все эти же числа, но не в виде строк, а в виде...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Andsteadur
153 / 137 / 3
Регистрация: 23.05.2009
Сообщений: 275
24.08.2012, 17:53 #2
C++
1
2
string str = "My name is Vendetta";
string name = str.substr(11, 8);
1
Пaтрик
415 / 390 / 38
Регистрация: 21.01.2012
Сообщений: 972
Завершенные тесты: 1
24.08.2012, 17:55 #3
C++
1
2
3
4
5
6
7
8
9
#include <iostream>
#include <string>
 
int main()
{
    std::string str = "My name is Vendetta";
    str = str.substr(11, 8);
    std::cout << str << std::endl;
}
1
vendeme
-32 / 3 / 3
Регистрация: 22.06.2011
Сообщений: 88
24.08.2012, 22:54  [ТС] #4
А как тоже с алгоритмом STL заменить слово с указанием позиций?
например:

C++
1
2
3
std::string str = "My name is Vendetta";
// дальше буквы с 12 по 19 заменить пробелом (не нужно менять размер)
// в итоге:  "My name is         ";
0
OhMyGodSoLong
~ Эврика! ~
1243 / 992 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
24.08.2012, 23:04 #5
Использовать нужный вариант replace же.
C++
1
2
3
4
5
6
7
8
9
10
#include <string>
#include <iostream>
 
int main()
{
  std::string str = "My name is Vendetta";
  std::cout << "\"" << str << "\"" << std::endl;
  str.replace(11, 8, 8, ' ');
  std::cout << "\"" << str << "\"" << std::endl;
}
1
vendeme
-32 / 3 / 3
Регистрация: 22.06.2011
Сообщений: 88
24.08.2012, 23:12  [ТС] #6
Понятно, а как искать в строке слово, игнорируя указанные символы?

Например:
C++
1
2
3
4
5
6
7
string str =  "M$y #na$me #is $#V#$en$#d$e$#$tt#$a$#$";
string findStr = "Vendetta";
string ignoreStr = "#$";
 
// но искать findStr игнорируя ignoreStr 
if(str.find(findStr) != std::string::npos) ...
// если нашли
0
gray_fox
What a waste!
1520 / 1223 / 70
Регистрация: 21.04.2012
Сообщений: 2,560
Завершенные тесты: 3
24.08.2012, 23:33 #7
Можно так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
#include <string>
#include <algorithm>
 
#include <boost/algorithm/string.hpp>
 
 
int main() {
   std::string const str =  "M$y #na$me #is $#V#$en$#d$e$#$tt#$a$#$";
   std::string const findStr = "Vendetta";
   std::string const ignoreStr = "#$";
   
   std::string copy(str);
   copy.erase(std::remove_if(copy.begin(), copy.end(), boost::is_any_of(ignoreStr)), copy.end());
   if (copy.find(findStr) != std::string::npos) {
      // ...
   }
}
1
OhMyGodSoLong
~ Эврика! ~
1243 / 992 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
24.08.2012, 23:33 #8
Боюсь, это уже сильно круто для одной функции. Я не особо круто знаю STL, даю 30% что там есть filter или что-то подобное обобщённое. Можно сделать так:
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
#include <iostream>
#include <string>
 
std::string filter(const std::string &str, const std::string &chars)
{
  std::string result;
  for (std::string::const_iterator i = str.begin(); i != str.end(); ++i) {
    if (chars.find(*i) == std::string::npos) {
      result.append(1, *i);
    }
  }
  return result;
}
 
int main()
{
  std::string str =  "M$y #na$me #is $#V#$en$#d$e$#$tt#$a$#$";
  std::string findStr = "Vendetta";
  std::string ignoreStr = "#$";
  
  if (filter(str, ignoreStr).find(findStr) !=  std::string::npos) {
    std::cout << "found";
  }
  else {
    std::cout << "not found";
  }
}
1
vendeme
-32 / 3 / 3
Регистрация: 22.06.2011
Сообщений: 88
24.08.2012, 23:41  [ТС] #9
Благодарю, просто интересно методы опытных, как решают некоторые задачи.
Ещё вопрос про find. find возвращает начальную позицию найденного слова, а как узнать конечную позицию?
0
OhMyGodSoLong
~ Эврика! ~
1243 / 992 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
24.08.2012, 23:42 #10
rfind ищет с конца.
1
vendeme
-32 / 3 / 3
Регистрация: 22.06.2011
Сообщений: 88
24.08.2012, 23:44  [ТС] #11
например:
C++
1
2
string str = "My name is Vendetta. Blah blah";
string::size_type n = str.find("Vendetta");
как узнать конечную позицию?
0
gray_fox
What a waste!
1520 / 1223 / 70
Регистрация: 21.04.2012
Сообщений: 2,560
Завершенные тесты: 3
24.08.2012, 23:47 #12
Цитата Сообщение от vendeme Посмотреть сообщение
например:
Код C++
1
2
string str = "My name is Vendetta. Blah blah";
string::size_type n = str.find("Vendetta");
как узнать конечную позицию?
C++
1
2
std::string search = "Vendetta";
std::string::size_type n = str.find(search) + search.length();   // # следующего за последним
1
vendeme
-32 / 3 / 3
Регистрация: 22.06.2011
Сообщений: 88
24.08.2012, 23:59  [ТС] #13
Цитата Сообщение от ~OhMyGodSoLong~ Посмотреть сообщение
Боюсь, это уже сильно круто для одной функции. Я не особо круто знаю STL, даю 30% что там есть filter или что-то подобное обобщённое. Можно сделать так:
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
#include <iostream>
#include <string>
 
std::string filter(const std::string &str, const std::string &chars)
{
  std::string result;
  for (std::string::const_iterator i = str.begin(); i != str.end(); ++i) {
    if (chars.find(*i) == std::string::npos) {
      result.append(1, *i);
    }
  }
  return result;
}
 
int main()
{
  std::string str =  "M$y #na$me #is $#V#$en$#d$e$#$tt#$a$#$";
  std::string findStr = "Vendetta";
  std::string ignoreStr = "#$";
  
  if (filter(str, ignoreStr).find(findStr) !=  std::string::npos) {
    std::cout << "found";
  }
  else {
    std::cout << "not found";
  }
}
А можно метод, без изменения размера строки? Допустим я потом хочу заполучить оригинальные позиций нахождения букв findStr?
И всё таки хотелось бы более STL варианта
0
rangerx
1933 / 1542 / 141
Регистрация: 31.05.2009
Сообщений: 2,912
25.08.2012, 00:08 #14
Цитата Сообщение от vendeme Посмотреть сообщение
Понятно, а как искать в строке слово, игнорируя указанные символы?
Почитайте про регулярные выражения.
0
OhMyGodSoLong
~ Эврика! ~
1243 / 992 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
25.08.2012, 00:26 #15
Цитата Сообщение от vendeme Посмотреть сообщение
А можно метод, без изменения размера строки? Допустим я потом хочу заполучить оригинальные позиций нахождения букв findStr?
И всё таки хотелось бы более STL варианта
Разработчики STL не могут предусмотреть все возможные извращения, к сожалению.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.08.2012, 00:26
Привет! Вот еще темы с ответами:

Реализация класса MyString. Стандартная библиотека, std::string, std::vector - C++
как добавить реализацию конкатенации строк через перегрузку оператора &quot;+=&quot; в классе MyString и почему ошибка выдается???#include...

Операция std::cout для Объекта типа std::string - C++
Кто детально объяснит почему не выводит ? Дает вот так &quot;Отсутствует оператор &quot;&lt;&lt;&quot;, соответствующий этим операндам&quot; void...

Передача функции указатель на элемент std::vector<std::string> - C++
Доброй ночи тем, кому не спится (или живет в другом часовом поясе:p)! Есть функция, требующая в качестве параметра указатель на...

Как правильно перевести std::wstring в std::string ? - C++
Собственно как? :)


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
25.08.2012, 00:26
Ответ Создать тему
Опции темы

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