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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C++]Работа со сторками (класс string), программа для поиска слов в строке 
V
    Опции темы
DiNeo
Дата 15.6.2010, 08:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



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

Вот мое решение без использования методов класса 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 методы, пожалуйста.

Это сообщение отредактировал(а) DiNeo - 15.6.2010, 08:16
PM MAIL ICQ   Вверх
azesmcar
Дата 15.6.2010, 08:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


uploading...
****


Профиль
Группа: Участник Клуба
Сообщений: 6291
Регистрация: 12.11.2004
Где: Армения

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



что за дурацкое задание?

забейте гвоздь в стену, пользуйтесь только ножовкой. smile 

что значит только методами string? cin и cout - это не методы string, это вообще не методы, так как задачу решать? Может все таки еще что-то можно использовать?
PM   Вверх
DiNeo
Дата 15.6.2010, 15:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



В основном нужно использовать класс string
Вот пример:

Код

void main ()
{
    string s,s1,*s2;//Cоздали два объекта класса 
                    //string и указатель на объект классса string
    int k=0;
    string razd=" ,.:"; 
/*Создали объект класса string, с помощью конструктора копирования для хранения разделителей между словами */
    string glas="aeoiuy"; 
/*Создали объект класса string, с помощью конструктора копирования для хранения гласных*/
    cout<<"Enter string  ";
    getline(cin,s);//Считали строку из потока cin
    s2=new string [s.length()/2];//Выделили память под 
                            //массив строк
    s1=s;
/* Скопировали строку s в строку s1 с помощью переопредленной операции = */

    int n= s1.find_first_of(razd);
/*Нашли позицию первого разделителя в строке s1*/
    while (n!=NPOS)
    {
        if (n)
        {
            s2[k]=s1.substr(0,n); 
/*Сохранили подстроку до разделителя как очередной элемент массива */
            if (glas.find(s2[k][0])!=NPOS)cout<<"\n"<<s2[k];
            k++;
        }
        s1=s1.substr(n+1); 
/*Далее рассматриваем только оставшуюся часть строки*/
        n=s1.find_first_of(razd);//Нашли позицию очередного 
                            //разделителя
    }
    s2[k]=s1; //Обработка последнего слова
    if (glas.find(s2[k][0])!=NPOS)cout<<"\n"<<s2[k];
}


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


Новичок



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

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



помогите кто-нибудь.. 
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

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


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

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

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

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


 




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


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

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