Решите тест по ассемблеру 3.Сколько существовало языков низкого уровня, последовательно сменивших друг друга1)1
2)2
3)3
4)4
4.Вычислительная система – это
1)совокупность не только аппаратных, но и программных средств
2)совокупность только аппаратных
3)совокупность только программных средств
4)ни один из предложенных вариантов неверен
5.Ассемблер - это
1)компилятор с языка ассемблера в команды машинного языка
2)интерпретатор с языка ассемблера в команды машинного языка
3)транслятора с языка ассемблера в команды машинного языка
4)деинтерпритатор с языка ассемблера в команды машинного языка
6.Что не является недостатком языков ассемблера
1)большие объемы кода
2)трудоемкость чтения и поиска ошибок
3)непереносимость на другие платформы
4)небольшой набор символов по сравнению с языками высокого уровня
7.Комментарий описывается следующей диаграммой
1):
2);
3).
4),
8.Директива - это
1)команда, выполняемая транслятором во время обработки программы
2)документация, которой придерживается программист
3)коментарииописанные диаграммой
4)указание команды (инструкции) процессора
9.Основная единица ассемблерной программы - это
1)символ
2)строка
3)блок
4)число
10.Описание сегмента оканчивается директивой
1)segment
2)segment ends
3)segment end
4)ends
11.Максимальный размен сегмента ограничен и составляет
1)2^16
2)2^8
3)2^32
4)2^4
12.Директивы определения общего режима трансляции определяют глобальные особенности трансляции, которые должны учитываться при обработке текста программы
1)режимов трансляции
2)секционирования программы
3)макросредств
4)резервирования данных
13.Директивы предназначенные для оформления логически законченных участков программы1)режимов трансляции
2)секционирования программы
3)макросредств
4)резервирования данных
14.Директивы позволяющие при написании программы оперировать заранее заготовленными фрагментами текстов
1)режимов трансляции
2)секционирования программы
3)макросредств
4)резервирования данных
15.Директивы размещающие в случае необходимости, инициализирующие области памяти под данные программы
1)режимов трансляции
2)секционирования программы
3)макросредств
4)резервирования данных
16.Директивы размещающие в случае необходимости, инициализирующие области памяти под данные программы
1)режимов трансляции
2)секционирования программы
3)макросредств
4)резервирования данных
17.В программной модели процессора х86 имеется:
1)31 регистр
2)21 регистр
3)32 регистра
4)22 регистра
18.В программной модели процессора х86 имеется регистров прикладного программиста: 1)13
2)14
3)15
4)16
19.В программной модели процессора х86 имеется регистров системного программиста: 1)13
2)14
3)15
4)16
20.Сколько используется регистров общего назначения
1)4
2)8
3)16
4)32
21.Сколько бит содержат регистры общего назначения
1)4
2)8
3)16
4)32
22.Какие регистры используются как указательные
1)EBP, ESI, EDI и ESP
2)ЕАХ, ЕВХ, ЕСХ, EDX, EBP, ESI, EDI и ESP.
3)АХ, ВХ, СХ, DX, BP, SI, DI и SP.
4)АН и AL
23.Что означает системный флажок VM
1)виртуальный режим
2)защищенный режим
3)возобновление
4)низший приоритет
24.Что означает системный флажок R
1)виртуальный режим
2)защищенный режим
3)возобновление
4)низший приоритет
25.Что означает системный флажок NT
1)виртуальный режим
2)вложенная задача
3)текущая задача
4)низший приоритет
26.Что означает системный флажок IOPL
1)виртуальный режим
2)прерывание
3)трассировка
4)уровень привилегии ввода/вывода
27.Что означает системный флажок Т
1)виртуальный режим
2)прерывание
3)трассировка
4)уровень привилегии ввода/вывода
28.Флажки действуют только на циклические команды
1)флажки управления
2)флажки состояния
3)системные флажки
4)прикладной флажк
#include <iostream>
using namespace std;
int amountNum(int a)
{
int count = 0;
while(a > 0)
{
a /= 10;
count++;
}
return count;
}
bool check(int a)
{
while(a > 0)
{
int k = a % 10;
if(k % 2 != 0)
return false;
a /= 10;
}
return true;
}
int main()
{
int num;
cin >> num;
if(amountNum(num) != 3)
{
cout << "Incorrect input";
return 0;
}
if(check(num))
cout << "YES";
else
cout << "NO";
}
1. Создадим массив для хранения информации о количестве встретившихся цифр во введенном числе.
2. Ввод самого числа, далее в цикле находим остаток от деления на 10 и увеличиваем значение элемента массива с индексом равным получившемуся остатку на 1. Делим число нацело на десять. Повторяем пока число не равно 0.
3. Выводим результат. В массиве индекс элемента указывает на цифру числа, а значение элемента на количество этой цифры в числе.
//РасаlABC.net v3.1
var a:array[0..9]of integer;
n,i,m: integer;
begin
readln(n);
repeat
m:=n mod 10;
inc(a[m]);
n:=n div 10;
until n<=0;
for i := 0 to 9 do begin
if a[i]>1 then writeln('Цифра:',i,' количество:', a[i]);
end;
end.
Тестовый прогон:
1112333
Цифра:1 количество:3
Цифра:3 количество:3