Varianta i
1. continuati enuntul:
in limbajul pascal există
tipuri de subprograme şi anume:
2. scrieți adevărat (a) sau fals (f) in dependentă de faptul dacă este sau nu de
endenta de faptul dacă este sau nu adevărată afirmatia:
a sau f
afirmatia
d o procedură poate avea doar parametri formali valoare
2) o functie poate fi utilizată doar o singură dată intr-un program pascal
3) parametrul actual transmite valoarea din programul principal in procedura.
4) un parametru actual poate fi o valoare
5) un subprogram obligatoriu trebuie să conţină un parametru formal
0) / procedurile pot intoarce mai multe rezultate prin intermediul parametrilor variabilă
7) procedurile si functiile pot rezolva aceiaşi problema
8) exp(x) este o procedură predefinită a limbajului pascal.
se consideră antetul:
var a,b: char; e,r: real; di: integer;
procedure p(var x: char; var y: real; z: integer);
ercuiti apelurile corecte.
// Внимание! Если программа не работает, обновите версию!
begin
var fn:='MtFile.bin';
var n:=ReadInteger;
var f:file of integer;
var s:=SeqRandom(n,-3000,8000); // последовательность не хранится
Rewrite(f,fn);
foreach var m in s do Write(f,m);
f.Close; // файл создан и закрыт
Reset(f,fn);
var b:integer; // буфер
while not Eof(f) do begin Read(f,b); Print(b) end; Writeln;
Seek(f,0); // стали в начало файла
Read(f,b);
var iOdd:=0;
while not Eof(f) and b.IsEven do
begin Read(f,b); iOdd+=1 end;
if Eof(f) and b.IsEven then
begin Writeln('Нет нечетных компонентов'); exit end;
var (bb,iEven):=(b,n);
repeat
iEven-=1; Seek(f,iEven); Read(f,b)
until (iEven=1) or b.IsEven;
if b.IsOdd then begin Writeln('Нет четных компонентов'); exit end;
Seek(f,iEven); Write(f,bb);
Seek(f,iOdd); Write(f,b);
Seek(f,0);
while not Eof(f) do begin Read(f,b); Print(b) end; Writeln;
f.Close
end.
Пример
10
3166 6355 3596 6926 1266 6143 7401 7624 1402 -627
3166 1402 3596 6926 1266 6143 7401 7624 6355 -627
fsz,indf,indl: int64;
f: file of integer;
begin
write('n = '); readln(n);
// запись в файл целых чисел
assign(f,'input.txt');
rewrite(f);
for i:=1 to n do write(f,random(-3000,8000));
close(f);
// замена элементов в файле
assign(f,'input.txt');
reset(f);
fsz:=FileSize(f);
indf:=0;
for i:=0 to fsz-1 do
begin
read(f,n);
if ((n mod 2)<>0) and (indf=0) then
begin
indf:=i; fs:=n;
end;
if (n mod 2)=0 then
begin
indl:=i; ls:=n;
end;
end;
reset(f);
seek(f,indf);
write(f,ls);
reset(f);
seek(f,indl);
write(f,fs);
close(f);
end.