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

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

Войти
Регистрация
Восстановить пароль
 
_20_
11 / 10 / 1
Регистрация: 29.09.2011
Сообщений: 260
#1

Посчитать количество столбцов в строке, разделённых произвольным количеством белых знаков - C++

11.08.2014, 03:46. Просмотров 436. Ответов 7
Метки нет (Все метки)

Необходимо посчитать количество столбцов в строке, разделённых произвольным количеством белых знаков (кроме знака конца стоки).

Также прошу подсказать, как реализовать такую конструкцию символов(буфер? поток?), из который можно было бы читать словами (>>), но при этом каждое следующие читание читало бы следующее слово.
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.08.2014, 03:46
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Посчитать количество столбцов в строке, разделённых произвольным количеством белых знаков (C++):

Посчитать в строке количество слов с одним пробелом и с произвольным их количеством - C++
Запросить у пользователя строку с символами, и посчитать в ней количество слов с одним пробелом и с произвольным их количеством

Посчитать количество знаков пунктуации во введенной строке - C++
Эти символы (: ; ? ! , . ) Язык C

Посчитать количество знаков препинания в строке. Чем заменить break? - C++
Чем можно заменять первый break в первом пункте меню, стобы программа работала нормально? надо посчитать количество знаков препинания в...

Посчитать количество знаков препинания в тексте и вывести их количество. - C++
Текст:"Враг, что мудр и много знает, друга может быть ценней. Мудрость уважать пристало у врагов и у друзей."

Посчитать количество смен знаков заданных чисел массива - C++
1. Задан массив из 10 целых чисел. Посчитать количество смен знаков заданных чисел. Перебор элементов массива должен осуществляться...

Создание функций, с произвольным количеством аргументов - C++
Всем доброго. Мне нужно создать функцию(с произвольным количеством аргументов), который использует первую(тоже с произвольным количеством...

7
QGuest
8 / 8 / 0
Регистрация: 08.01.2013
Сообщений: 85
11.08.2014, 04:52 #2
Цитата Сообщение от _20_ Посмотреть сообщение
Также прошу подсказать, как реализовать такую конструкцию символов(буфер? поток?), из который можно было бы читать словами (>>), но при этом каждое следующие читание читало бы следующее слово.
Вот например:

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
57
58
59
60
61
62
63
64
65
66
67
68
#include <iostream>
#include <string>
#include <vector>
#include <fstream>
 
using namespace std;
 
class WordReader {
private:
    ifstream& stream;
    vector<string> buffer;
public:
    WordReader(ifstream& stream) : stream(stream) {}
 
    //Функция разделяет строку на части с помощью разделителей (delimiters)
    static vector<string> split(string data, string delimiters) {
        vector<string> parts;
 
        auto lastPos = data.find_first_not_of(delimiters, 0);
        auto pos = data.find_first_of(delimiters, lastPos);
        
        while (pos != string::npos || lastPos != string::npos) {
            parts.push_back(data.substr(lastPos, pos - lastPos));
            
            lastPos = data.find_first_not_of(delimiters, pos);
            pos = data.find_first_of(delimiters, lastPos);
        }
        
        return parts;
    }
 
    //Проверка на существование следущего слова в файле
    bool hasNext() {
        return stream.eof() ? !buffer.empty() : true;
    }
 
    //Оператор считывания
    WordReader& operator>>(string& word) {
        if (hasNext()) {
            if (buffer.empty()) {
                string line;
                getline(stream, line);
                buffer = split(line, " ");
            }
            
            if(buffer.size() > 0) {
                word = buffer[0];
                buffer.erase(buffer.begin());
            }
            else word = "";
        }
        else word = "";
        return *this;
    }
};
 
void main() {
    ifstream file("D:\\text.txt");
    WordReader reader(file);
 
    while (reader.hasNext()) {
        string buf;
        reader >> buf;
        cout << buf << endl;;
    }
 
    getchar();
}
Добавлено через 2 минуты
Цитата Сообщение от _20_ Посмотреть сообщение
Необходимо посчитать количество столбцов в строке, разделённых произвольным количеством белых знаков (кроме знака конца стоки).
Вообще не понял о чем речь. Столбцы в строке? Белые знаки? Пробелы имеются в виду?
1
_20_
11 / 10 / 1
Регистрация: 29.09.2011
Сообщений: 260
11.08.2014, 05:49  [ТС] #3
Большое спасибо Вам за ответ. Сейчас уже поздно, поэтому я только мельком просмотрел код. Возможно я действительно плохо описал поблемму, попробую на примере. Имеем файл, достаём оттуда первую строку:
2.333323 23.23222222 0.111212221212111121
(движок форума удаляет повторные пробелы, но предположим, что числа разделены заранее неизвстной комбирацией пробелов и табуляций).
И надо посчитать, что чисел 3 штуки. Числа могут быть разделены разным количеством пробелов и знаков табуляции. Конечно же можно читать посимвольно и считать циферки и пробелы, но мне кажется, что были более удобные механизмы для этого. А потом записать эти три цифры в три переменных типа double.

Вот если делать так:
C++
1
2
3
4
    std::string str, tmp;
    std::ifstream file(path.c_str());
    if(file ==0) return;
    std::getline(file, str);
то потом
C++
1
    file >> tmp;
читает первое слово. Должен же быть способ прочитать второе, третие слово?
0
zss
Модератор
Эксперт С++
6485 / 6048 / 1985
Регистрация: 18.12.2011
Сообщений: 15,689
Завершенные тесты: 1
11.08.2014, 07:54 #4
Цитата Сообщение от _20_ Посмотреть сообщение
Должен же быть способ прочитать второе, третье слово
А чем не подходит обычный способ:
C++
1
2
3
4
double w[3];
int i=0;
while( file>>w[i] && i<3)
   i++;
1
_20_
11 / 10 / 1
Регистрация: 29.09.2011
Сообщений: 260
11.08.2014, 12:12  [ТС] #5
Да вот не работает оно у меня как надо. Такой кой:
C++
1
2
3
4
5
6
7
    double w[3];
    int i=0;
    while( file>>w[i] && i<3)
       i++;
    for(int j=0; j<3; ++j){
        std::cout << w[j]<< std::endl;
    }
Такой вывод:
5.28274e-308
5.28307e-308
2.94632e+230

Вводный файл такой:
123 7822 127
212 9999
222
111
0
zss
Модератор
Эксперт С++
6485 / 6048 / 1985
Регистрация: 18.12.2011
Сообщений: 15,689
Завершенные тесты: 1
11.08.2014, 13:22 #6
Вот так работает
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int main() 
{
    ifstream file("D:\\text.txt");
    double w[3];
    int i=0;
    while(  i<3 && file>>w[i])
       i++;
    for(int j=0; j<i; ++j){
        std::cout << w[j]<< std::endl;
    }
    system("pause");
    return 0;
}
0
BlackIce
310 / 172 / 64
Регистрация: 18.01.2014
Сообщений: 387
11.08.2014, 13:45 #7
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <string>
#include <sstream>
#include <fstream>
#include <iostream>
using namespace std;
 
int main() {
    ifstream file("input.txt");
    int strcnt = 0;
    while (file) {
        string s;
        if (!getline(file, s)) break;
        cout << "строка #" << ++strcnt << "; числа:";
        istringstream ss(s);
        double value;
        while (ss >> value) cout << ' ' << value;
        cout << endl;
    }
}
Входной файл:
Код
123 7822 127
212 9999
222
111
Вывод:
Код
строка #1; числа: 123 7822 127
строка #2; числа: 212 9999
строка #3; числа: 222
строка #4; числа: 111
1
_20_
11 / 10 / 1
Регистрация: 29.09.2011
Сообщений: 260
11.08.2014, 14:15  [ТС] #8
Спасибо большое.
не могли бы Вы меня просветить и по поводу подсчёта, правильно ли я делаю и нельзя ли сделать проще?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void readFile(std::string path){
    std::string str, tmp;
    std::stringstream txt (std::stringstream::in | std::stringstream::out);
    std::ifstream file(path.c_str());
    if(file ==0) return;
    std::getline(file, str);
    std::cout<<str<<"---str "<<std::endl;
    txt << str;
    std::string ww[3];
    int k=0;
    while( k<3 && txt>>ww[k]){
       ++k;
    }
    for(int j=0; j<k; ++j){
        std::cout << ww[j]<< "===  " << j <<std::endl;
    }
Добавлено через 10 минут
Тему можно закрывать, BlackIce уже дал образец кода, а я и не заметил.
0
11.08.2014, 14:15
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.08.2014, 14:15
Привет! Вот еще темы с ответами:

Функции с произвольным количеством и типом аргументов. - C++
Начал изучать ф-ции с определенным количеством параметров и при изучении возник вопрос, а именно: #include &lt;iostream&gt; using...

Найти количество знаков препинания в строке - C++
задана строка.найти количество знаков препинания в строке C++

Подсчитать количество знаков препинания в строке. - C++
Подсчитать количество знаков препинания в строке.

В строке подсчитать количество знаков препинания - C++
В общем задание обстоит так:Ввести с экрана строку. В строке подсчитать количество знаков препинания (запятая,точка, восклицательный знак)....


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

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

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