Var a,b,t,m,r :integer;
Function F(x:integer):integer;
begin
F:= x*x + 2*x + 10;
end;
BEGIN
a:=-10; b:=10;
M:=a; R:=F(a);
for t:=a to b do begin
if (F(t)< R)then begin
M:=t;
R:=F(t);
end;
end;
write(M);
END.
Массивы. Типовые задачи обработки массивов.
-
Задание 1
Задание 2
В программе описан одномерный целочисленный массив с индексами от 0 до 10. В приведенном ниже фрагменте программы массив сначала заполняется, а потом изменяется:
for i:=0 to 10 do
A[i]:= i + 1;
for i:=1 to 10 do
A[i]:= A[i-1];
Как изменяются элементы этого массива?
1) все элементы, кроме последнего, сдвигаются на 1 элемент вправо
2) все элементы, кроме первого, сдвигаются на 1 элемент влево
3) все элементы окажутся равны 1
4) все элементы окажутся равны своим индексам
Дан фрагмент:
for n:=l to 6 do
for m:=l to 5 do begin
C[n,m]:=C[n,m]+(2*n-m);
end;
Чему будет равно значение С[4,3], если перед этими командами значение С[4,3]=10?
1) 5
2) 10
3) 15
4) 25
Символьный тип данных.
Задание 1 По заданной программе найдите значение переменной res1 и res2:
Program primer;
Var res1,res2:boolean;
c1,c2,c3,c4:char;
begin
c1:=’b’;
c2:=’x’;
res1:=c1 < c2;
c3:=#12;
c4:=#150;
res1:=c3 < c4;
writeln (‘’’b’’>’’c’’= ‘,res1);
writeln ( ‘#12>#150=’,res2);
END.
Строки символов.
Задание 1 По заданной программе найдите значение переменной n:
Program primer;
Var st,st1,st2:string;
I,n:integer;
begin
n:=0;
st1:=’микрокопирование’;
st2:=’микрофильмирование’;
st:=copy(st1,1,10)+copy(st2,5,7);
for i:=1 to length(st) do
if st[i] =’и’ then n:=n+1;
write(st);
write(n);
END.
C1 Пример задания:
Требовалось написать программу, при выполнении которой с клавиатуры считывается координата точки на прямой (х – действительное число) и определяется принадлежность этой точки одному из выделенных отрезков В и D (включая границы). Программист торопился и написал программу неправильно.
V ar X: real;
begin
readln(x) ;
if x<=l4 then
if x>=-4 then
if x>=8 then
write('принадлежит')
else
write('не принадлежит')
end.
Последовательно выполните следующее.
1. Перерисуйте и заполните таблицу, которая показывает, как работает программа при аргументах, принадлежащих различным областям (А, В, С, D и Е). Границы (точки -4, 2, 8 и 14) принадлежат заштрихованным областям.
Область |
Условие 1 (x<=14) |
Условие 2 (х>=-4 |
Условие 3 (х>=8) |
Программа выведет |
Область обрабатывается верно |
А |
|
|
|
|
|
В |
|
|
|
|
|
С |
|
|
|
|
|
D |
|
|
|
|
|
Е |
|
|
|
|
|
В столбцах условий укажите «да», если условие выполнится, «нет», если условие не выполнится, «—» (прочерк), если условие не будет проверяться, «не изв.», если программа ведет себя по-разному для разных значений, принадлежащих данной области. В столбце «Программа выведет» укажите, что программа выведет на экран. Если программа ничего не выводит, напишите «—» (прочерк). Если для разных значений, принадлежащих области, будут выведены разные тексты, напишите «не изв.». В последнем столбце укажите «Да» или «Нет».
2. Укажите, как нужно доработать программу, чтобы не было случаев её неправильной работы. (Это можно сделать несколькими способами, достаточно указать любой способ доработки исходной программы.)
c2 Пример задания:
Дан целочисленный массив из 20 элементов. Элементы массива могут принимать целые значения от 0 до 1000. Опишите на русском языке или на одном из языков программирования алгоритм, позволяющий найти и вывести минимальное значение среди элементов массива, которые имеют чётное значение и не делятся на три. Гарантируется, что в исходном массиве есть хотя бы один элемент, значение которого чётно и не кратно трем.
Исходные данные объявлены так, как показано ниже. Запрещается использовать переменные, не описанные ниже, но использовать все описанные переменные не обязательно.
program primer;
const N=20;
