Для чтения/записи файлов в C# можно использовать несколько подходов в зависимости от задачи. Например, если нужно вывести весь текст из файла в консоль - можно использовать File.ReadAllText(). Если же нужно форматировать каждую строку файла или, например, необходимо считывать текст файла по одному символу - можно использовать StreamReader. Разумеется, считывать с файла можно не только сплошной текст. Это могут быть байты, отдельные строки; опять же в зависимости от задачи. Аналогичная ситуация с записью в файл. Для записи используем File.WriteAllBytes() или StreamWriter. Классы File, StreamReader, StreamWriter и др. находятся в пространстве имен System.IO. Обязательно напишите строку кода: using System.IO; или обращайтесь к классу так: System.IO.File.ReadAllLines(); Также хочу сразу предотвратить возможную ошибку: если вы открываете файл для записи/чтения, не забудьте освободить ресурсы. Иначе файл так и останется открытым, и если к нему еще раз обратиться, то будет ошибка. Для этого закрывайте файл или освобождайте ресурсы вручную: File.Create().Close(); или reader.Dispose(); Но есть возможность делать это автоматически. Для этого нужно использовать using как в моем коде.
Для наглядности привожу пример программы. Задача: считать из файла имена людей и записать в другой файл отсортированный список. Затем взять сообщение из файла, закодировать, поместить закодированное сообщение в файл. Получить из файла закодированное сообщение, расшифровать и вывести в консоль. Для решения использовал основные приемы для чтения/записи файла. Также сделал краткие комментарии. Надеюсь, всё было понятно. Поскольку в ответе код скорее всего отформатируется криво, прикрепил фотографию с "красивым" кодом, а также фотографию входных и выходных файлов.
Код:
using System;
using System.IO;
using System.Text;
using System.Collections.Generic;
namespace ConsoleApp1
{
internal class Program
{
private static void Main(string[] args)
{
//Путь к входным и выходным файлам.
const string inputPath1 = @"D:\ProgramsTester\Input1.txt";
const string inputPath2 = @"D:\ProgramsTester\Input2.txt";
const string outputPath1 = @"D:\ProgramsTester\Output1.txt";
const string outputPath2 = @"D:\ProgramsTester\Output2.txt";
//Список.
List<string> items = new List<string>();
//Использует StreamReader, а затем высвобождает ресурсы.
using (StreamReader reader = new StreamReader(inputPath1))
{
//Читает весь файл.
while (!reader.EndOfStream)
{
items.Add(reader.ReadLine());
}
}
//Сортировка массива.
items.Sort();
//Использует StreamWriter, а затем высвобождает ресурсы.
using (StreamWriter writer = new StreamWriter(outputPath1))
{
//Записывает отсортированный список в файл.
for (int i = 0; i < items.Count; i++)
{
writer.WriteLine(items[i]);
}
}
//Байты из файла, хранящего сообщение, записываются в массив байт.
byte[] fileBytes = File.ReadAllBytes(inputPath2);
//Запись закодированного сообщения в файл.
File.WriteAllText(outputPath2, Convert.ToBase64String(fileBytes));
//Вывод декодированного сообщения, полученного из файла.
Console.WriteLine("Decoded text: " + Encoding.Default.GetString(Convert.FromBase64String(File.ReadAllText(outputPath2))));
_ = Console.ReadKey();
}
}
}
from collections import deque
n, k = map(int, input().split())
x, d, ssum = list(map(int, input().split())), deque(), 0
b = [(0,0) for i in range(n)]
for i in range(n):
ssum += x[i]
if i >= k :
ssum -= x[i - k]
if d[0] == i - k :
d.popleft()
while len(d) and x[d[-1]] >= x[i]:
d.pop()
d.append(i)
if i >= k - 1:
nb = (b[i-k][0] + x[d[0]] * ssum, i-k+2)
b[i] = max(b[i-1], nb, key=lambda x: x[0])
i = n - 1
d = deque()
j = b[-1][1]
d.appendleft(j)
while i !=0:
i -= 1
j1 = b[i][1]
if j-k>=j1 and j1 > 0 :
d.appendleft(j1)
j = j1
print(str(len(d)))
print(" ".join(map(str, d)))
Находим количество символов
50*60*4=12000 символов= 12000 бит
переведем в более крупную систему счисления
12000/1024=11,71875 Кб
ответ: 11,7 Кб