Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
22 / 56 / 9
Регистрация: 29.09.2011
Сообщений: 618

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

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

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

Также прошу подсказать, как реализовать такую конструкцию символов(буфер? поток?), из который можно было бы читать словами (>>), но при этом каждое следующие читание читало бы следующее слово.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.08.2014, 03:46
Ответы с готовыми решениями:

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

В строке посчитать количество слов, разделенных пробелами
Переведите на ассемблер, не понимаю это. Задание: посчитать количество слов в строке разделенные пробелами. var s:string; ...

Посчитать количество знаков препинания в строке
Вводится строка. Посчитать количество знаков препинания. Помогите решить пожалуйста

7
8 / 8 / 0
Регистрация: 08.01.2013
Сообщений: 85
11.08.2014, 04:52
Цитата Сообщение от _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
22 / 56 / 9
Регистрация: 29.09.2011
Сообщений: 618
11.08.2014, 05:49  [ТС]
Большое спасибо Вам за ответ. Сейчас уже поздно, поэтому я только мельком просмотрел код. Возможно я действительно плохо описал поблемму, попробую на примере. Имеем файл, достаём оттуда первую строку:
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
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,246
11.08.2014, 07:54
Цитата Сообщение от _20_ Посмотреть сообщение
Должен же быть способ прочитать второе, третье слово
А чем не подходит обычный способ:
C++
1
2
3
4
double w[3];
int i=0;
while( file>>w[i] && i<3)
   i++;
1
22 / 56 / 9
Регистрация: 29.09.2011
Сообщений: 618
11.08.2014, 12:12  [ТС]
Да вот не работает оно у меня как надо. Такой кой:
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
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,246
11.08.2014, 13:22
Вот так работает
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
318 / 180 / 73
Регистрация: 18.01.2014
Сообщений: 387
11.08.2014, 13:45
Лучший ответ Сообщение было отмечено _20_ как решение

Решение

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;
    }
}
Входной файл:
Code
1
2
3
4
123 7822 127
212 9999
222
111
Вывод:
Code
1
2
3
4
строка #1; числа: 123 7822 127
строка #2; числа: 212 9999
строка #3; числа: 222
строка #4; числа: 111
1
22 / 56 / 9
Регистрация: 29.09.2011
Сообщений: 618
11.08.2014, 14:15  [ТС]
Спасибо большое.
не могли бы Вы меня просветить и по поводу подсчёта, правильно ли я делаю и нельзя ли сделать проще?
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.08.2014, 14:15
Помогаю со студенческими работами здесь

Посчитать количество знаков препинания в строке
Дана строка-предложение на русском языке. Подсчитать количество содержащихся в строке знаков препинания.

Посчитать количество знаков препинания в строке
Нужно написать программы для решения 2-х задач по теме &quot;строки&quot;. Задача №1. Посчитать количество знаков препинания в строке. Посчитать...

Посчитать количество знаков препинания в строке
Только без метода IsPunctuation а знаки занести в массив как мне это сделать ? using System; using System.Linq; namespace...

Посчитать количество знаков пунктуации в строке
Напишите программу, которая считает знаки пунктуации в символьной строке. К знакам пунктуации относятся символы из набора «.,;:!?». ...

Посчитать количество знаков препинания в строке
Посчитать количество знаков препинания в строке. Посчитать в строке количество символов «:» и «;».


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru