Для работы с файлами из своей программы необходимо:
fstream
, содержащий описание функций, позволяющих
работать с файловыми потоками.
ifstream
,
связав его с файлом на диске. Чтение данных из файла осуществляется также, как
из стандартного ввода при помощи оператора “>>
”
ofstream
,
связав его с файлом на диске. Запись данных в файл осуществляется также, как
на стандартный вывод при помощи оператора “<<
”
Если при связывании объектов с файлами указывается только имя файла (а не полный путь), то файл должен располагаться в текущем каталоге (там же, где и запускаемая программа).
Пример работы с файлами:
#include <fstream> using namespace std; ifstream fin("input.txt"); ofstream fout("output.txt"); int main() { int a, b; fin >> a >> b ; // Считать числа a и b из файлового потока fin fout << a + b << endl; return 0; }
Напоминаем, что строки можно считывать из файла двумя способами - до пробельного символа
при помощи оператора fin >> S
и до конца строки при помощи функции
getline(fin, S)
.
Также из листка про строки рекомендуется вспомнить, как читать данные посимвольно или построчно до конца файла,
как работает манипулятор noskipws
.
В задачах J-Z этого листка нельзя сохранять все входные данные в массиве, размер которого определяется количеством записей во входном файле, за исключением тех задач, где явно сказано произвести сортировку всех записей входного файла по заданному критерию. Также в этих задачах запрещается повторное считывание входного файла.
Входные данные записаны в файле input.txt
,
результат работы нужно вывести в файл output.txt
.
Во входном файле записано два целых числа, не превосходящие 2×109 по модулю. Выведите в выходной файл их сумму.
Ввод | Вывод |
---|---|
2 2 |
4 |
Во входном файле записана одна текстовая строка, возможно, содержащая пробелы. Выведите эту строку в обратном порядке.
Строка во входном файле заканчивается символом конца строки '\n'
.
Вы также должны вывести конец строки в выходной файл.
Ввод | Вывод |
---|---|
hello world |
dlrow olleh |
Выведите все строки данного файла в обратном порядке. Для этого создайте массив строк, считайте файл построчно в данный массив, затем выведите строки из массива в обратном порядке.
Количество строк в файле не превосходит 1000.
Ввод | Вывод |
---|---|
Beautiful is better than ugly. |
Complex is better than complicated. |
Выведите в обратном порядке содержимое всего файла полностью.
Для этого считайте весь файл посимвольно и запишите его в массив символов.
Не забудьте про noskipws
!
Количество байт в файле не превосходит 106.
Ввод | Вывод |
---|---|
Beautiful is better than ugly. |
|
В выходной файл выведите все строки наибольшей длины из входного файла, не меняя их порядок.
В этой задаче удобно считать файл два раза: при первом считывании файла определить длину самой длинной строки, при втором считывании файла вывести все строки такой длины.
Для повторного считывания файла сначала нужно закрыть ранее открытый файл при
помощи метода close()
, потом заново открыть его при помощи метода
open
с параметром — именем файла:
fin.close(); fin.open("input.txt");
Ввод | Вывод |
---|---|
One |
Twenty one |
Определите, есть ли во входном файле символ '@'
. Выведите
слово YES
или NO
.
Входной файл может быть очень большим, поэтому считывать файл нужно посимвольно.
Ввод | Вывод |
---|---|
Valid email: |
YES |
Hello, world! |
NO |
В файле могут быть записаны десятичные цифры и все, что угодно. Числом назовем последовательность цифр, идущих подряд (т.е. число всегда неотрицательно).
Вычислите сумму всех чисел, записанных в файле. В данной задаче удобно считывать данные посимвольно,
не забудьте про noskipws
.
Ввод | Вывод |
---|---|
123 |
600 |
Дан файл. Определите сколько в нем букв (латинского алфавита), слов, строк. Выведите три найденных числа в формате, приведенном в примере.
Слово — это последовательность букв (заглавных и строчных) латинского алфавита.
Для экономии памяти читайте файл посимвольно, то есть не сохраняя целиком в памяти файл или отдельные его строки.
Ввод | Вывод |
---|---|
Beautiful is better than ugly. |
Input file contains: |
Зашифруйте данный текстовый файл шифром Цезаря, при этом символы первой строки файла должны циклически сдвигаться на 1, второй строки — на 2, третьей строки — на три и т.д.
В этой задаче удобно считывать файл построчно, шифруя каждую строку в отдельности.
Ввод | Вывод |
---|---|
Hello |
Ifmmp |
В олимпиаде по информатике принимало участие несколько человек.
Информация о результатах олимпиады записана в файле,
каждая строка которого имеет вид:
фамилия имя класс балл.
Фамилия и имя — текстовые строки, не содержащие пробелов. Класс - одно из трех чисел 9, 10, 11. Балл - целое число от 0 до 100.
Победителем олимпиады становится человек, набравший больше всех баллов. Победители определяются независимо по каждому классу.
Определите количество баллов, которое набрал победитель в каждом классе. Гарантируется, что в каждом классе был хотя бы один участник.
Выведите три числа: баллы победителя олимпиады по 9 классу, по 10 классу, по 11 классу.
Ввод | Вывод |
---|---|
Иванов Сергей 9 90 |
93 91 92 |
В условиях предыдущей задачи определите и выведите средние баллы участников олимпиады в 9 классе, в 10 классе, в 11 классе.
Ввод | Вывод |
---|---|
Иванов Сергей 9 90 |
91.5 91 92 |
В условиях предыдущей задачи определите количество школьников, ставших победителями в каждом классе. Победителями объявляются все, кто набрал наибольшее число баллов по данному классу. Гарантируется, что в каждом классе был хотя бы один участник.
Выведите три числа: количество победителей олимпиады по 9 классу, по 10 классу, по 11 классу.
Ввод | Вывод |
---|---|
Иванов Сергей 9 80 |
2 2 1 |
Зачет в олимпиаде проводится без деления на классы. Выведите фамилию и имя победителя олимпиады. Если таких несколько - выведите только их количество.
Ввод | Вывод |
---|---|
Иванов Сергей 9 90 |
Сергеев Петр |
Иванов Сергей 9 90 |
2 |
Зачет проводится отдельно в каждом классе. Победителями олимпиады становятся школьники, которые набрали наибольший балл среди всех участников в данном классе.
Для каждого класса определите максимальный балл, который набрал школьник, не ставший победителем в данном классе.
Выведите три целых числа.
Ввод | Вывод |
---|---|
Иванов Сергей 9 80 |
80 81 82 |
Результаты олимпиады подводятся без деления на классы. Победителем олимпиады становятся те, кто набрал больше всего баллов. Призерами олимпиады становятся участники, следующие за победителями.
Определите наибольший балл, который набрали призеры олимпиады и количество участников олимпиады, набравших такой балл. Выведите два числа: наибольший балл призера и количество участников, имеющий такой балл.
Ввод | Вывод |
---|---|
Иванов Сергей 9 92 |
92 2 |
В условиях предыдущей задачи выведите фамилию и имя участника олимпиады, набравшего наибольший балл, но не ставшего победителем. Если таких школьников несколько - выведите их количество.
Ввод | Вывод |
---|---|
Иванов Сергей 9 93 |
Петров Василий |
Иванов Сергей 9 92 |
2 |
В олимпиаде по информатике принимало участие N человек.
Информация о результатах олимпиады записана в файле, каждая из строк которого имеет вид:
фамилия имя школа балл
Фамилия и имя — текстовые строки, не содержащие пробелов. Школа — целое число от 1 до 99. Балл — целое число от 0 до 100.
Определите школы, из которых в олимпиаде принимало участие больше всего участников. Выведите номера этих школ в порядке возрастания.
В этой задаче необходимо считывать данные построчно, не сохраняя в памяти данные обо всех участниках, а только подсчитывая число участников для каждой школы.
Ввод | Вывод |
---|---|
Иванов Сергей 14 56 |
3 14 |
В условиях предыдущей задачи определите школы, из которых в олимпиаде принимало участие меньше всего участников (но был хотя бы один участник). Выведите номера этих школ в порядке возрастания.
Ввод | Вывод |
---|---|
Иванов Сергей 14 56 |
23 27 |
Известно, что фамилии всех участников — различны. Сохраните в массивах список всех участников и выведите его, отсортировав по фамилии в лексикографическом порядке.
При выводе указываете фамилию, имя участника и его балл.
Число строк в файле не превосходит 106.
Ввод | Вывод |
---|---|
Иванов Сергей 14 56 | Андреев Роман 75 |
Отсортируйте список участников олимпиады:
Выведите список в таком же виде, как в предыдущей задаче.
Число строк в файле не превосходит 106.
Ввод | Вывод |
---|---|
Иванов Сергей 14 75 |
Петров Василий 99 |
В условиях предыдущей задачи выведите в порядке возрастания номера школ, в которых есть хотя бы один победитель олимпиады.
Ввод | Вывод |
---|---|
Иванов Сергей 13 80 |
13 35 |
В условиях предыдущей задачи выведите в порядке возрастания номера школ, средний балл учащихся которых выше, чем средний балл всех участников олимпиады (то есть необходимо вычислить средний балл для каждой школы и средний балл по всем участникам).
Ввод | Вывод |
---|---|
Иванов Сергей 13 45 |
20 |
В условиях предыдущей задачи выведите в порядке возрастания номера школ, средний балл учащихся которых максимален (то есть необходимо вычислить средний балл для каждой школы и вывести те школы, средний балл для которых максимален).
Ввод | Вывод |
---|---|
Иванов Сергей 13 45 |
20 |
В условиях предыдущей задачи выведите номера школ, из которых был хотя бы один участник олимпиады, в порядке убывания количества участников олимпиады из этих школ. Если из двух школ было одинаковое число участников, то их номера выводятся в порядке возрастания номера школы.
Ввод | Вывод |
---|---|
Иванов Сергей 13 45 |
13 70 14 20 |
В условиях предыдущей задачи выведите номера школ, из которых был хотя бы один участник олимпиады, в порядке убывания среднего балла участников олимпиады из этих школ. Если для двух школ средний балл участников совпадает, то их номера выводятся в порядке возрастания номера школы.
Ввод | Вывод |
---|---|
Иванов Сергей 13 45 |
20 70 13 |
В условиях предыдущей задачи выведите в порядке возрастания номера школ, из которых наибольшее количество участников стало победителями олимпиады.
Ввод | Вывод |
---|---|
Иванов Сергей 13 70 |
20 |