Нужна с Асемблером! Нужно написать на ассемблере задачки. Номер 1
В программу вводиться 2 натуральных числа: A и B. Если A делится на B, то вывести частное, иначе вывести оба числа.
Номер 2
В программу вводиться натуральное число. Нужно программе подсчитать содержащееся в нём количество простых множителей, равных 5-ти.
Номер 3
В программу вводиться X натуральных чисел. Нужно программе посчитать, сколько среди введённых чисел чётных и нечётных.
Номер 4
В программу вводиться натуральное число X . Подсчитать X !. Если X! не вмещается в ячейку памяти (переполнение), вывести -1.
Номер 5
Вычислить приближённое значение натурального числа е по формуле:
r = 1 + 1/2! + 1/1! +1/3! + 1/4!;
Номер 6
В программу вводиться 2 натуральных числа: A и B. Вычислить C = AB. Если C не вмещается в ячейку памяти (переполнение), вывести -1.
Номер 7
В программу вводиться в произвольном порядке три положительных и три отрицательных числа. Вывести сначала отрицательные числа, а затем - положительные.
Номер 8
В программу вводиться три числа и вывести их в порядке возрастания.
Номер 9
Алгоритм Герона для вычисления квадратного корня x = a1/2. Ввести положительное число a.
Принять в первом приближении
x1 = a/2;
Вычислять по формуле
xi = (a/xi-1 + xi-1)/2 ,
пока |a - xi*xi| > 0.001*a.
Номер 10
В программу вводиться натуральное число a. Определить, в какой из следующих диапазонов оно попадает:
1. 0 ≤ a ≤ 10 ;
2. 10 1000 .
Вывести номер диапазона.
Номер 11
В программу вводиться X чисел x1, x2, . xX, X > 3.
Вывести xi, если xi > xi-1, i =2, 3, ..X.
Номер 12
В программу вводиться X чисел. Найти их среднее арифметическое.
Номер 13
В программу вводиться коды ASCII двух чисел. Вывести в арабских цифрах большее из них.
Номер 14
В программу вводиться число записанное арабскими цифрами. Вывести его в кодах ASCII.
Номер 15
В программу вводиться X чисел. Найти их произведение.
Номер 16
В программу вводиться коды ASCII X символов. Выбрать из них и вывести только коды цифр.
Номер 17
Вводить натуральные числа до тех пор, пока не выполнится условие:
Xi ≥ Xi-1 + Xi-2.
Номер 18
Вводятся коды символов в UTF-8. Нужно выводить только коды цифр.
Номер 19
Вводить натуральные числа до тех пор, пока не будет введено такое число a, что
a + a = a * a = a2. (1)
P.s:(1) Должно проверяться в программе даже, если Вы догадались, что это за число.
Номер 20
Вводить натуральные числа до тех пор, пока не будут введены три таких числа a, b и с, что
a2+ b2 = c2.
Выведите эти числа.
// PascalABC.Net 3.0, сборка 1066
procedure CheckString(var s:string; var n:integer);
var
i:integer;
begin
i:=Length(s);
while i>0 do begin
if not(s[i] in ['a'..'z']) then Delete(s,i,1);
Dec(i)
end;
n:=Length(s)
end;
var
s1,s2:string;
i,p,n1,n2:integer;
begin
Write('Введите первую строку: '); Readln(s1);
CheckString(s1,n1);
if n1=0 then Writeln('Введенная строка не содержит допустимых символов')
else begin
Write('Введите вторую строку: '); Readln(s2);
CheckString(s2,n2);
if n2=0 then Writeln('Введенная строка не содержит допустимых символов')
else
{ теперь обе строки содержат только маленькие латинские буквы }
if n1=n2 then begin
for i:=1 to n1 do begin
p:=Pos(s1[i],s2);
if p=0 then Break
else Delete(s2,p,1)
end;
if Length(s2)=0 then Writeln('Решение имеется')
else Writeln('Решения нет')
end
else
Writeln('Решения нет');
end
end.
Тестовое решение:
Введите первую строку: this is my own deal!
Введите вторую строку: Тест: *is now=l2ead my sthi?
Решение имеется
Также имеется современное решение, которому пока что в школах не учат:
// PascalABC.Net 3.0, сборка 1066
begin
var s1:=ReadString('Введите первую строку: ').Where(x->x in ['a'..'z']);
if s1.Count=0 then
Writeln('Введенная строка не содержит допустимых символов')
else begin
var s2:=ReadString('Введите вторую строку: ').Where(x->x in ['a'..'z']);
if s2.Count=0 then
Writeln('Введенная строка не содержит допустимых символов')
else
if s1.Except(s2).Count>0 then Writeln('Решения нет')
else Writeln('Решение имеется')
end
end.
var a : array [1..3, 1..4] of integer
b : array [1..3] of integer
Max, i, j : integer
BEGIN
crt;
for i:=1 to 3 do
begin
for j:=1 to 4 do
begin
read (a[i, j]); // вводим элементы в массив a[1..3, 1..4]
end;
writeln; // делаем пустой перевод строки
end;
for i:=1 to 3 do
begin
b[i] := a[i, 1];
for j:=1 to 4 do
begin
if a[i, j] > b[i] then b[i] := a[i, j];
// находим максимальный элемент в каждой строке и записываем в b[1..3]
end;
end;
Max := b[1];
for i:=1 to 3 do if b[i] > Max then Max := b[i];
// Находим максимальный элемент из максимальных элементов
writeln (Max); // Выводим его на экран
END.