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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Вывести символ на экран, если он является буквой или цифрой http://www.cyberforum.ru/cpp-beginners/thread1308449.html
1. Вывести символ на экран, если он является буквой или цифрой (Функции для работы с символами. Цель – освоить работу и основные манипуляции с различными символами). 2. Переставьте соседние элементы массива - диапазон изменения значений элементов массива (Одномерные массивы. Цель – познакомиться с одномерными массивами).
C++ Возвращение массива в качестве результата выполнения метода класса (Kubuntu, netBeans, g++) Всем привет. Пытаюсь написать свой первый демон на C++ по образу и подобию сделанного на PHP. Столкнулся со следующей проблемой. В PHP у меня был универсальный класс, методы которого принимали массивы параметров запроса к mysql (поля, таблицы и т.д.), после чего выполняли операции над базой данных по этим параметрам. Пытаюсь сейчас воспроизвести это в с++. http://www.cyberforum.ru/cpp-beginners/thread1308435.html
задача с функциями C++
Помогите пожалуйста написать код, никак не могу понять, что нужно делать: При выводе текстов на экран или печатающее устройство часто используются табуляционные остановки - выделенные позиции строки. Например, при печати таблиц полезно зафиксировать положение столбцов таблиц. Если в исходном тексте встречается символ табуляции tab (например, символ с кодом 9), это означает, что текст, следующий...
Инициализация char в конструкторе C++
class Abit { public: Abit(); ~Abit(); protected: private: bool medal;
C++ Найти максимум и произведение элементов массива через функции http://www.cyberforum.ru/cpp-beginners/thread1308371.html
#include <iostream> using namespace std; int vvod_dannih() { setlocale(0,""); int i,n,mas; cout<<"Введите количество элементов массива :"; cin>>n; for (i = 0; i < n ; i++)
C++ Как найти самое длинное (короткое) слово? как найти самое длинное(самое короткое) слово? #include <iostream> #include <sstream> #include <string> #include <algorithm> #include <assert.h> int main() подробнее

Показать сообщение отдельно
Ev[G]eN
Эксперт С++
 Аватар для Ev[G]eN
5093 / 1531 / 381
Регистрация: 23.01.2011
Сообщений: 3,148
23.11.2014, 17:28     Получить массив из слов
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;
}
 
Текущее время: 20:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru