1. дано целое число а. не пользуясь никакими арифметическими операциями, кроме умножения, получите а19 за 6 операций. можно использовать дополнительные переменные2. составьте программу на языке паскаль для вычисления y по формуле , где - заданное целое число.3. определите значения переменных a, b, c, x после выполнения программы на паскале, если при вводе их значения равны a=15, b=5, c=10: program primer; var a, b, c, x: integer; begin readln (a, b, c); x: =a-b+c; a: =b*5; b: =с+b; с: =b; b: =a*3; writeln (‘a=’, a, ’b=’, b, ‘c=’, c, ‘x=’, x)end.4. определите значение переменной х после выполнения фрагмента программы на паскале: а: =1; в: =а/2*4; х: =2; if a< =b then x: =5 else x: =a+b-x; 5. напишите программу на паскале для решения следующей : даны два числа x и y, не равные друг другу. меньшее из этих чисел замените их частным, а большее их удвоенной разностью. 6.
uses GraphABC;
var
n, i: integer;
a: array of integer = (0,0, 100,270, 85,170, 240,165, 250,65, 410,65, 413,170, 405,270, 100,270, //кузов
0,0, 251,165, 260,75, 328,75, 320,165, 280,225, 245,225, 251,165, 320,165, //дверь
0,0, 330,165, 338,75, 400,75, 403,165, 330,165, //окно
0,0, 170,167, 170,140, 180,137, 180,70, 185,65, 185,137, 195,140, 195,166,//труба
0,0, 168,290, 105,353, 42,290, 105,227, 168,290, 0,0, 163,314, 81,348, 47,266, 129,232, 163,314,
0,0, 150,335, 60,335, 60,245, 150,245, 150,335, 0,0, 129,348, 47,314, 81,232, 163,266, 129,348, //п.колесо
0,0, 463,265, 375,353, 287,265, 375,177, 463,265, 0,0, 456,299, 341,346, 294,231, 409,184, 456,299,
0,0, 437,327, 313,327, 313,203, 437,203, 437,327, 0,0, 409,346, 294,299, 341,184, 456,231, 409,346); //з.колесо
begin
for n := 0 to Length(a) div 2 - 1 do
begin
i := 2*n;
if (a[i] = 0) and (a[i + 1] = 0)
then
MoveTo(a[i + 2], a[i + 3])
else
LineTo(a[i], a[i + 1]);
end;
end.
Проверял в PascalABC.NET 3.4.2
Правда, предварительно ещё рассчитал все точки обоих колёс вот по этой программе (но, это уже так, просто для сведения):
var
x1, y1, r1, x2, y2, r2: integer;
n, i: integer;
a: real;
begin
x1:=105; y1:=290; r1:=63;
x2:=375; y2:=265; r2:=88;
for i := 0 to 3 do
begin
write (0,',',0,', ');
for n := 0 to 4 do
begin
a:=90*(n mod 4)+22.5*i;
write (Round(r1*Cos(Pi*a/180))+x1,',', Round(r1*Sin(Pi*a/180))+y1,', ');
end;
end;
writeln ();
for i := 0 to 3 do
begin
write (0,',',0,', ');
for n := 0 to 4 do
begin
a:=90*(n mod 4)+22.5*i;
write (Round(r2*Cos(Pi*a/180))+x2,',', Round(r2*Sin(Pi*a/180))+y2,', ');
end;
end;
write (');');
end.
Составим программу вычисления суммы ряда чисел 5, 10, 15, …, 50 на языке программирования Pascal ABC. Введем обозначения следующих величин: пусть s – сумма чисел ряда, которую надо найти, а i – порядковый номер чисел ряда. Начальное значение суммы s будет равным нулю. Так как чисел несколько, то будем использовать в программе оператор цикла с параметром for. По условию задачи числа суммируются, начиная с числа 5, с интервалом 4 числа, поэтому значение i в каждом цикле будем увеличивать на 4.
Программа может выглядеть так:
program zadacha;
uses crt;
var s,i: integer;
begin
s:=0; {Задание начального значение суммы s}
for i:=5 to 50 do begin
s:=s+i; {Вычисление суммы чисел}
i:=i+4; {Увеличение значения параметра i на 4}
end;
writeln ('s=',s) {Вывод результата суммы s}
end.
Можно решить данную задачу и вторым используя операцию mod:
program zadacha;
uses crt;
var s,i: integer;
begin
s:=0; {Задание начального значение суммы s}
for i:=5 to 50 do
if i mod 5=0 {Поиск чисел, кратных 5}
then s:=s+i; {Вычисление суммы чисел}
writeln ('s=',s); {Вывод результата суммы s}
end.
ответом будет s=275.
Составить программу нахождения значения функции у= 5х+х2, при х=50, 49, 48, 47, …, 40.
program zadacha;
uses crt;
var x,y,i:integer;
begin
for i:=50 downto 40 do begin y:=5*i+i*2; writeln ('y=',y); end;
writeln ('y=',y)
end.
Объяснение: