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

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

Войти
Регистрация
Восстановить пароль
 
HanDi
890 / 337 / 8
Регистрация: 11.02.2012
Сообщений: 1,502
#1

Получить массив из слов - C++

23.11.2014, 14:45. Просмотров 224. Ответов 2
Метки нет (Все метки)

Необходимо разработать функцию, которая будет возвращать массив слов, содержащихся в сообщении

char** Words(char *s)

Допустим есть строка:

C++
1
char str[] = "Мама мыла раму, умара алым амам. Один, два; три!";
Пытаюсь сделать что-то в этом роде:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 char** Words(char *s)
    {
        int n;
        n = strlen(s);
        char** mass[n][n];
         
    for(int i = 0; i < n; i++)
    {
      for(int j = 0; j < n; j++)
      {
        while (**mass[i] != "," || **mass[i] != "!" || **mass[i] !="." || **mass[i] !=";")
          **mass[j][i]=s[i];
      }
    }
        
      return **mass;    
    }
Был еще вариант с copystr (помещать в массив каждое слово, которое находим), но тоже никак.

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

Функция, получает строку слов и рзделителей, а на выходе имеет массив слов из строки и количество этих слов - C++
мне нужна функция, которая во входе получает строку слов и рзделителей (&quot; &quot;, &quot;,&quot;, &quot;.&quot;, &quot;_&quot;, &quot;&quot;&quot;), а на выходе имеет массив слов из строки...

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

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

Использование библиотеки STL , контейнер string. Дан массив слов.Надо удалить все цифры из слов - C++
#include &quot;StdAfx.h&quot; #include &lt;string&gt; #include &lt;iostream&gt; #include &lt;algorithm&gt; using namespace std; int main() { string str...

Ввод слов в массив и подсчёт введённых слов - C++
как можно решить эту задачу:Напишите программу,использующую массив char и цикл для чтения по одному слову за раз до тех пор,пока не будет...

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

2
zss
Модератор
Эксперт С++
6477 / 6040 / 1981
Регистрация: 18.12.2011
Сообщений: 15,648
Завершенные тесты: 1
23.11.2014, 16:31 #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
#include <iostream>
#include <strstream>
using namespace std;
char** Words(char *s, int& n)
{
  istrstream is(s); // создаем поток из строки
  int L=strlen(s); 
  char* tmp=new char[L+1];
  n=0;   // количество слов
  int LMax=0; // Макс длина строки
  do
  {
      is>>tmp;
      n++;
      L=strlen(tmp);
      if(L>LMax)
          LMax=L;
  }while(!is.eof());
   delete[] temp;
  char** mass=new char*[n]; // к-во строк n
  for(int i = 0; i < n; i++)
      mass[i]=new char[LMax+1];  // каждая строка длиной не более LMax 
  is.seekg(0);  // Начинаем читать сначала
  for(int i = 0; i < n; i++)
      is>>mass[i]; // вводим очередное слово
  return mass;    
}   
int main()
{
    char** x;
    int N;
    char txt[]="qqqq 112we;hy lll,99";
    x=Words(txt,N);
    for(int i=0;i<N;i++)
        cout<<x[i]<<endl;
    for(int i=0;i<N;i++)
        delete[] x[i];
    delete[] x;
    system("pause");
    return 0;
}
0
Ev[G]eN
iOS/Android Developer
Эксперт С++
5097 / 1535 / 381
Регистрация: 23.01.2011
Сообщений: 3,148
23.11.2014, 17:28 #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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <iostream>
#include <cstring>
#include <clocale>
 
size_t countOfWordsInString(char *string, const char *delimeters = " ?!;:,.");
char **stringTokenizer(char *string, const char *delimeters = " ?!;:,.");
 
int main()
{
    std::setlocale(0, "");
 
    char string[] = "Мама мыла раму, умара алым амам. Один, два; три!";
    
    char **wordsList = stringTokenizer(string);
    for (size_t i = 0; i < countOfWordsInString(string); i++) {
        std::cout << wordsList[i] << std::endl;
    }
    
    for (size_t i = 0; i < countOfWordsInString(string); i++) {
        delete [] wordsList[i];
    }
    delete [] wordsList;
    wordsList = nullptr;
 
    std::system("pause");
    return 0;
}
 
size_t countOfWordsInString(char *string, const char *delimeters)
{
    size_t countOfWords = 0;
    char *tempString = new char [strlen(string) + 1];
    strcpy(tempString, string);
    char *nextStringToken = strtok(tempString, delimeters);
    while (nextStringToken) {
        nextStringToken = strtok(nullptr, delimeters);
        countOfWords++;
    }
    return countOfWords;
}
 
char **stringTokenizer(char *string, const char *delimeters)
{
    char *tempString = new char[strlen(string) + 1];
    strcpy(tempString, string);
    
    size_t index = 0;
    char **wordsList = new char *[countOfWordsInString(string)];
    char *currentWord = strtok(tempString, delimeters);
    while (currentWord) {
        wordsList[index] = new char[strlen(currentWord) + 1];
        strcpy(wordsList[index++], currentWord);
        currentWord = strtok(nullptr, delimeters);
    }
    return wordsList;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.11.2014, 17:28
Привет! Вот еще темы с ответами:

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

Получить 10 наиболее часто встречающихся слов в файле - C++
ребята, срочно нужна помощь в решении задачи!)) Жду , заранее спасибо:) Дан текстовый файл f, содержащий более 1000 слов. Получить 10...

Массив: Получить массив из максимальных значений каждого из входных массивов. - C++
Найти максимальное значение в массиве. Результат операции – массив с максимальных значений каждого из входных массивов. Я нашёл...

Дан двумерный массив 3х3. Получить одномерный массив из из отрицательных элементов матрицы. - C++
Пожалуйста, помогите решить простым методом задачку, просто не могу понять смысл ее выполнения. Дан двумерный массив 3х3.Получить...


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

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

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