Студопедия — Команды для типизированных файлов
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Команды для типизированных файлов






 

Чтение из типизированного файла осуществляется по одной компоненте в переменную или переменные, которые должны совпадать по типу с типом компонент файла.

 

Read (f, x); - чтение из типизированного файла одной компоненты в переменную x.

Read (f, x1, x2, x3, ... xn); - чтение из файла нескольких компонент в переменные.

Write (f, x); - запись в файл значения x. Запись начинается с того места, где был

установлен указатель файла.

Seek (f, n); - для типизированных файлов (прямого доступа) устанавливает

указатель файла на компоненту с номером n.

Eof (f) - функция, определяющая признак конца файла. Принимает значение True,

если указатель текущей позиции файла находится за последним элементом

файла либо файл пустой

Eoln – функция, определяет признак конца строки при считывании строк из

текстовых файлов

Truncate (f); - удаление части файла, начиная с места, где установлен указатель файла.

FilePos (f); - функция, определяет позицию указателя файла.

FileSize (f); - функция, определяет размер файла (число компонент).

 


Задача 13.1.

Определить сумму нечетных по значениям компонент типизированного файла, и записать полученную сумму вместо максимального значения в файле.

 

Текст программы к задаче 13.1.


Program Ex_12_1;

Uses Crt;

Label A;

Var f2: file of integer;

x: integer; {компонента}

i: integer; {счетчик цикла}

S: integer; {сумма}

Max: integer; {максимум}

k: integer; {номер максимума}

Begin

ClrScr;

Randomize;

Assign(f2, ‘g: \f2.dat’);

{Запись чисел в файл}

Rewrite(f2);

Writeln(‘Исходный файл: ’);

Writeln;

For i: =0 to 15 do begin

x: =random(100)-50;

Write(f2, x);

Write(x: 3);

End;

{Подсчет суммы нечетных компонент}

Reset(f2);

For i: =0 to 15 do begin

Read(f2, x);

If x mod 2< > 0 then

S: =S+x;

End;

{Примем первую компоненту за Max}

Reset(f2);

Read(f2, x);

Max: =x;

{Поиск Max в файле}

For i: =1 to 15 do begin

Read(f2, x);

If x> Max then begin

Max: =x;

k: =i

End;

{Запись суммы вместо Max в файле}

Seek(f2, k);

Write(f2, S);

{Вывод результатов}

Writeln(‘Измененный файл: ’);

Writeln;

Reset(f2);

While not Eof(f2) do begin

Read(f2, x);

Write(x: 3);

End;

Close(f2);

Readln;

End.



Задача 13.2.

Найти первое отрицательное и последнее отрицательное значения среди компонент типизированного файла, и поменять местами эти компоненты в файле. Найти произведение компонент файла, стоящих между первым отрицательным и последним отрицательным значением.


Текст программы к задаче 13.2.


Program Ex_12_2;

Uses Crt;

Label A;

Var

f1: file of integer;

x: integer; {компонента}

Otr1, Otr2: integer; {отрицательные}

k1, k2: integer; {номера отриц.}

i: integer; {счетчик цикла}

Begin

ClrScr;

Randomize;

Assign(f1, ‘g: \f1.dat’);

 

{Запись чисел в файл}

Rewrite(f1);

Writeln(‘Исходный файл: ’);

Writeln;

For i: =0 to 15 do begin

x: =random(100)-50;

Write(f1, x);

Write(x: 3);

End;

 

{Поиск первого отрицательного}

Reset(f1);

For i: =0 to 15 do begin

Read(f1, x);

If x< 0 then begin

Otr1: =x;

k1: =i;

Goto A;

{Как только нашли, выходим из цикла}

End;

End;

{Поиск последнего отрицательного}

A: Reset(f1);

For i: =0 to 15 do begin

Read(f1, x);

If x< 0 then begin

Otr2: =x;

k2: =i;

End;

End;

{Обмен в файле значений местами }

Seek(f1, k1);

Write(f1, Otr2);

Seek(f1, k2);

Write(f1, Otr1);

 

{Подсчет суммы ком. между k1 и k2}

i: =k1+1;

Repeat

Seek(f1, i);

Read(f1, x);

S: =S+x;

i: =i+1;

Until i< k2;

 

{Вывод результатов}

Writeln(‘Измененный файл: ’);

Writeln;

Reset(f1);

While not Eof(f1) do begin

Read(f1, x);

Write(x: 3);

End;

Close(f1);

Readln;

End.



Схема программы к задаче 13.2








Дата добавления: 2014-11-12; просмотров: 566. Нарушение авторских прав; Мы поможем в написании вашей работы!



Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...

Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...

ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...

Тема: Изучение приспособленности организмов к среде обитания Цель:выяснить механизм образования приспособлений к среде обитания и их относительный характер, сделать вывод о том, что приспособленность – результат действия естественного отбора...

Тема: Изучение фенотипов местных сортов растений Цель: расширить знания о задачах современной селекции. Оборудование:пакетики семян различных сортов томатов...

Тема: Составление цепи питания Цель: расширить знания о биотических факторах среды. Оборудование:гербарные растения...

Определение трудоемкости работ и затрат машинного времени На основании ведомости объемов работ по объекту и норм времени ГЭСН составляется ведомость подсчёта трудоёмкости, затрат машинного времени, потребности в конструкциях, изделиях и материалах (табл...

Гидравлический расчёт трубопроводов Пример 3.4. Вентиляционная труба d=0,1м (100 мм) имеет длину l=100 м. Определить давление, которое должен развивать вентилятор, если расход воздуха, подаваемый по трубе, . Давление на выходе . Местных сопротивлений по пути не имеется. Температура...

Огоньки» в основной период В основной период смены могут проводиться три вида «огоньков»: «огонек-анализ», тематический «огонек» и «конфликтный» огонек...

Studopedia.info - Студопедия - 2014-2024 год . (0.012 сек.) русская версия | украинская версия