Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 1
Регистрация: 23.05.2018
Сообщений: 7

Работа с файлами

29.05.2018, 16:42. Показов 854. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Товарищи, срочно нужна помощь, уже задавал подобный вопрос, но реализовать не смог.


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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
// программа считывает текст с консоли(то есть те, которые мы вводим), как сделать, чтобы она считывала с файла?
#include "stdafx.h"
#include <iostream>
#include <string>
#include <Windows.h>
#include <fstream>
 
 
using namespace std;
 
int main()
{
 
    setlocale(LC_ALL, "RUS");
 
    //Строка, с которой мы будем работать
    string str;
 
    //Промежуточная булевая переменная для
    //дальнейшей работы со строкой
    bool temp = false;
 
    //Служит для хранения длинны текущего слова
    int len = 0;
 
    //Хранит максимальную длину слова
    //по умолчанию - 0
    int maxlen = 0;
 
    //Ввод строки и проверка на пустоту;
    //str.empty() возвращает true если строка пустая
    while (true) {
        cout << "Введите строку слов:" << endl;
        getline(cin, str);
 
        if (str.empty() != true) {
            break;
        }
 
        cout << "Строка пустая, нажмите любую кнопку и попробуйте ещё раз" << endl;
        system("pause");
        system("cls");
    }
 
    //Поиск максимальной длины слова
    //Если длина строки равна 1-му, то задаются особые условия
    if (str.length() == 1) {
        if (str[0] != ' ') {
            maxlen = 1;
            cout << "Слова минимальной длины:" << endl;
            cout << str[0] << endl;
        }
        else {
            cout << "Слова отсутствуют." << endl;
        }
    }
    //В противном случае поиск по стандартным условиям
    else {
        //Проверка первых двух элемента строки на пробел или символ
        //temp отвечает за запись длинны слова (temp == true, len увеличивается)
        if (str[0] != ' ') {
            temp = true;
            len++;
        }
        if (str[0] == ' ' && str[1] != ' ') {
            temp = true;
        }
 
        //Проходим элементы начиная со 2-го
        //и заканчивая предпоследним
        for (int i = 1; i < str.size() - 1; i++) {
            //Если мы проходили слово(temp == true)
            //и слово закончилось(данный символ равен пробелу)
            //то сравниваем текущую длинну слова с минмальной
            //и возвращаем значения переменных temp и len к первоначальным
            int tt = str.size();
            if (temp && str[i] == ' ') {
                temp = false;
                if (maxlen < len) {
                    maxlen = len;
                }
                len = 0;
            }
            else {
                //Если мы проходим слово(temp == true)
                //и слово продолжается(данный символ не равен пробелу)
                //увеличиваем длинну слова(len) на 1
                if (temp && str[i] != ' ') {
                    len++;
                }
            }
            //Если текущий символ пробел и следующий не пробел
            //присваиваем temp = true и тем самым запускаем счётчик
            //подсчёта длинны слова из следующих символов
            if (str[i] == ' ' && str[i + 1] != ' ') {
                temp = true;
            }
        }
 
        //Проверка последенего символа
        if (str[str.size() - 1] != ' ') {
            len++;
            temp = false;
            if (maxlen < len) {
                maxlen = len;
                len = 0;
            }
        }
        else {
            if (temp) {
                temp = false;
                if (maxlen < len) {
                    maxlen = len;
                    len = 0;
                }
            }
        }
 
        //Возвращаем значения переменных temp и len к первоначальным
        len = 0;
        temp = false;
 
        /*===========================================================================*/
 
        cout << "Слова максимальной длины:" << endl;
 
        //Поиск слов заданной длины и их вывод в консоль
        //Особые условия для первого символа
        if (str[0] != ' ') {
            temp = true;
            len++;
        }
        if (str[0] == ' ' && str[1] != ' ') {
            temp = true;
        }
 
        //Прогон строки в цикле
        for (int i = 1; i < str.size() - 1; i++) {
            //Определение длины слова и сравнение с нужной длинной
            if (temp && str[i] == ' ') {
                temp = false;
                //Если слово искомое, то оно выводится в цикле в консоль
                //а счётчик len обнуляется
                if (maxlen == len) {
                    for (int j = 0; j < len; j++) {
                        cout << str[i - len + j];
                    }
                    cout << endl;
                    len = 0;
                }
            }
            else {
                if (temp && str[i] != ' ') {
                    len++;
                }
            }
            if (str[i] == ' ' && str[i + 1] != ' ') {
                temp = true;
                len = 0;
            }
        }
 
        //Особые условия для последнего символа
        if (str[0] != ' ') {
            len++;
            if (maxlen == len) {
                for (int j = 0; j < len; j++) {
                    cout << str[str.length() + j - len];
                }
                cout << endl;
            }
        }
        else {
            if (temp) {
                if (maxlen == len) {
                    for (int j = 0; j < len; j++) {
                        cout << str[str.length() + j - len];
                    }
                    cout << endl;
                }
            }
        }
 
        //Возвращаем значения переменных temp и len к первоначальным
        len = 0;
        temp = false;
    }
 
    system("pause");
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.05.2018, 16:42
Ответы с готовыми решениями:

Работа с файлами , хотелось бы с windows system файлами
всем привет, нужна интересная идея по программированию, работа с файлами , хотелось бы с windows system файлами, у вас есть какая-то идея?...

Лабораторная работа №5. Работа с файлами и алгоритмы сортировки
1. Написать функцию Load для считывания из текстового файла (например, Workers.txt) информации о работниках и заработной плате. В первой...

Работа с файлами(Запись,чтение,работа с данными)
Здравствуйте, никак не могу осилить файлы... Для начала вот само задание: В справочной автовокзала хранится расписание движения автобусов....

1
Модератор
Эксперт С++
 Аватар для zss
13778 / 10971 / 6491
Регистрация: 18.12.2011
Сообщений: 29,257
29.05.2018, 17:35
Никаких сложностей
1. создаете новый объект класса ifstream
[CPP]ifstream fin("c:\\data\\file.txt");
2. Проверяете, что он открылся
C++
1
2
3
4
if(fin)
{
// сюда код
}
3. Меняете cin на fin
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.05.2018, 17:35
Помогаю со студенческими работами здесь

Работа с файлами, чтение/работа со строкой
Доброго времени суток. Начал работать с C++ Builder 6. Есть текстовый файл .txt с различными строками, как можно производить...

Работа с файлами
Доброго дня суток уважаемые форумчане. Столкнулся с проблемой... На форме в Ворд есть три текстбокса. из их содержимого собирается...

Работа с файлами
Задача программы такова - пользователь вводит строку адреса , например C:\blablabla и программа считывает все размеры файлов хранящихся в...

Работа с файлами
Скажите поожалуйста как сделать что бы программа могла читать и записывать в любой фаил информацию т.е Могла читать из фаила и...

Работа с файлами
вот у меня такая проблема, я создаю файл FileInfo File = new FileInfo(&quot;file.txt&quot;); FileInfo.Create(); и теперь когда хочу...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru