Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C++]Строки,поиск слов, поиск вхождения слова в строку 
V
    Опции темы
DiNeo
Дата 18.6.2010, 07:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 21
Регистрация: 11.3.2010

Репутация: нет
Всего: нет



Дан набор слов и произвольная текстовая строка. Выбрать из текстовой строки все слова, входящие в данный набор и вывести их на печать. Использовать методы класса string.

Вот мое решение :

Код

#include <iostream>
#include <string>
#include <sstream>

using namespace std;

string * words;
string text;
int n;

void input()
{
   cout << "Введите количество слов для поиска :";
   cin >> n;
   words = new string[n];
   cout << "\nВведите " << n << " words :" << endl;
   for(int i = 0; i < n; i++)
       cin >> words[i];
   cout << "\nВведите текст в котором надо найти слова :" << endl;
   cin.ignore();
   getline(cin,text);
}

bool search(const string &s)
{
   for(int i = 0; i < n; i++)
       if(words[i] == s)
           return true;
   return false;
}

void solve()
{
   istringstream ss(text);
   string word;
   cout << "Слова, найденные в строке: ";
   while(ss >> word)
       if(search(word))
           cout << word << " ";
   cin.ignore();cin.get();
}

int main()
{
   setlocale (0,"Russian");
   input();
   solve();
   return 0;



Помогите переписать используя string методы, пожалуйста.

Вот методы:
Метод size_type  size() const  и метод size_type length() const возвращают размер строки.
    Метод insert (size_type posl, const string & str) вставляет строку str в вызывающую строку, начиная с позиции posl.
    Метод replace (size_type posl, size_type n1, const string & str) заменяет n1 элементов, начиная с позиции pos1 вызывающей строки, элементами строки str.
    Метод  string substr (size_type pos=0, size_type n=NPOS) const  возвращает подстроку длины n,  назиная с позиции pos.
    Метод size_type  find  (const string& str, size_type pos=0) const  / size_type  rfind  (const string& str, size_type pos=0) const  ищет самое левое/правое вхождение строки str в вызывающую строку, начиная с позиции pos, и возвращает позицию вхождения или NPOS, если вхождение не найдено. 
    Метод size_type  find  (char с, size_type pos=0) const  / size_type  find  (char с, size_type pos=0) const  ищет самое левое/ правое вхождение символа с в вызывающую строку, начиная с позиции pos, и возвращает позицию вхождения или NPOS, если вхождение не найдено. 
    Метод size_type  find_first_of  (const string& str, size_type pos=0) const/  size_type  find_last_of  (const string& str, size_type pos=0) const ищет самое левое/ правое вхождение любого символа строки str в вызывающую строку, начиная с позиции pos, и возвращает позицию вхождения или NPOS, если вхождение не найдено. 
    Метод swap  (const string& str)  обменивает содрежимое вызывающей строки и строи str. 
Метод erase (size_type pos=0, size_type n= NPOS) удаляет n элементов, начиная с позиции pos.
Метод clear () ощищает всю строку.
Метод   size_type  copy  (char * s, size_type n, size_type pos=0) const копирует в символьный массив s n элементов вызывающей строки, начиная с позиции pos. Возращается количество скопированных элементов.  

PM MAIL ICQ   Вверх
bsa
Дата 18.6.2010, 12:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Модератор
Сообщений: 9185
Регистрация: 6.4.2006
Где: Москва, Россия

Репутация: 1
Всего: 196




M
bsa
Для домашних заданий, курсовых и т.п. существует \"Центр Помощи\".




Тема перенесена. 
PM   Вверх
ИванМ
Дата 18.6.2010, 16:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1260
Регистрация: 19.6.2006
Где: СПб

Репутация: 13
Всего: 23



DiNeo, используйте методы substr и find. Как они работают, вы сами написали.
Хотя можно ограничиться только find.
Что-то в таком духе:
for(size_t i=0;i<length;i++)
  if(text.find(words[i]!=string::npos)
    cout<<words[i]<<endl;

Это сообщение отредактировал(а) ИванМ - 18.6.2010, 16:22
PM MAIL   Вверх
DiNeo
Дата 19.6.2010, 10:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 21
Регистрация: 11.3.2010

Репутация: нет
Всего: нет



ИванМ,  спасибо! сделал)
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0622 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.