Смекни!
smekni.com

Системы счисления Составление алгоритмов (стр. 1 из 2)

Министерство образования и науки Российской Федерации

Федеральное агентство по образованию

Государственное образовательное учреждение высшего профессионального образования

«Комсомольский-на-Амуре государственный технический университет»

Кафедра математического обеспечения и применения ЭВМ

РАСЧЕТНО-ГРАФИЧЕСКОЕ ЗАДАНИЕ

по специальности: 010503 – Математическое обеспечение и администрирование информационных систем

на тему: «СИСТЕМЫ СЧИСЛЕНИЯ. СОСТАВЛЕНИЕ АЛГОРИТМОВ»

Руководитель работы М.Е. Щелкунова

Исполнитель Д.А. Кантимиров

2010


Задание

1.) Заданы три числа А, В, С (таблица 1) соответственно в десятичном, двоичном и шестнадцатеричном виде. Каждое из этих чисел представить в двух других видах и в восьмеричном виде. А10=93. В2=1110001. С16=D5

а.) Организую перевод в двоичную систему счисления.

93:2=46 (1)

46:2=23 (0)

23:2=11 (1)

11:2=5 (1)

5:2=2 (1)

2:2=1 (0)

А2=01011101

Организую перевод в шестнадцатеричную систему счисления.

93:16=5 (D)

А16=5D

Организую перевод в восьмеричную систему счисления.

93:8=11 (5)

11:8= 1 (3)

А8=135

б.) В2=1110001

Организую перевод в десятичную систему счисления.

6543210 (нумерую числа по разрядам)

1110001

В10=1*2^6+1*2^5+1*2^4+1=64+32+16+1=11310

В10=113

Организую перевод в шестнадцатеричную систему счисления.

113:16=7 (1)

В16=71

Организую перевод в восьмеричную систему счисления.

113:8=14 (1)

14:18=1 (6)

В8=161

в.) С16= D5

Организую перевод в десятичную систему счисления.

1 0 (нумерую числа по разрядам)

D5

С10=13*16+5=213

С10=213

Организую перевод в двоичную систему счисления.

213:2=106 (1)

106:2=53 (0)

53:2=26 (1)

26:2=13 (0)

13:2=6 (1)

6:2=3 (0)

3:2=1 (1)

С2=0000000011010101 (т.к. 1 находящаяся на 8-ой позиции указывает на отрицательное число, в восьмиразрядную сетку число не влезает, буду работать в шестнадцатиразрядной)

Организую перевод в восьмеричную систему счисления

213:8=26 (5)

26:8=3 (2)

С8=325

2. Используя числа, заданные в таблице 1, вычислить по правилам двоичной арифметики: А+ B, А - B, В - А, B - Cдля ЭВМ с длиной разрядной сетки, равной 8. Выполнить проверку (перевести результаты в десятичную систему счисления).

а.) А+В.

А2=01011101

В2=01110001

Произвожу операцию сложения столбиком

01011101

+

01110001

11001110 (так как результат в восьмиразрядную сетку число не влезает, буду работать в шестнадцатиразрядной)


А+В=00000000110011102

Проверка

Х=00000000110011102

Х10=1*2^7+1*2^6+1*2^3+1*2^2+1*2=128+64+8+4+2=206

А10+ В10=93+113=206

206=206 – верно

б.) А-В

А2=01011101

В2=01110001

Для того, чтобы вычитание заменить сложением, перевожу В в –В (инвертирую).

В2=01110001

Инвертирую

10001110

+

_______1

10001111

Произвожу операцию сложения А и –В.

01011101

+

10001111

11101100 (т.к 8 число является единицей, это указывает на то , что число отрицательное. Необходимо проводить инвертирование).

Инвертирую

00010011

+

_______1

-10100 ;

А-В=-10100

Проверка

А-В=-10100 ; А-В=-(1*2^4 + 1*2^2)=-20

А-В=93-113= -20

-20=-20 - верно

в.) В-А

А2=01011101

В2=01110001

Для того, чтобы вычитание заменить сложением, перевожу А в –А (инвертирую).

А2=01011101

Инвертирую

10100010

+

_______1

10100011

Произвожу операцию сложения -А и В.

01110001

+

10100011

100010100 (т.к. существует девятое число, то можно сделать вывод о логическом переполнении, следовательно от девятого знака необходимо избавиться.)

В-А=00010100

Проверка

В-А=00010100 ; В-А=1*2^4+1*2^2=20

В-А=113-93=20

20=20 – верно.

г.) В-С

С2=0000000011010101 (т.к. 1 находящаяся на 8-ой позиции указывает на отрицательное число, в восьмиразрядную сетку число не влезает, буду работать в шестнадцатиразрядной)

В2=0000000001110001

Для того, чтобы вычитание заменить сложением, перевожу С в –С (инвертирую).

С2=0000000011010101

Инвертирую

1111111100101010

+

_______________1

1111111100101011

Произвожу операцию сложения -С и В.

1111111100101011

+

0000000001110001

1111111110011100 (т.к 16 число является единицей, это указывает на то , что число отрицательное. Необходимо проводить инвертирование).

Инвертирую

0000000001100011

+

_______________1

-1100100 ;

В-С=-1100100

Проверка

В-С=-1100100; В-С=-(1*2^6+1*2^5+1*2^2)= -(64+32+4)=-100

В-С=113-213=-100

-100=-100 – верно.

3.) Представить указанное в таблице число в четырехбайтовом IEEE формате.

А=345.867

Перевожу число в двоичную систему, при этом целая часть переводится отдельно от дробной.

Ι 345:2=172 (1)

172:2=86 (0)

86:2=43 (0)

43:2=21 (1)

21:2=10 (1)

10:2=5 (0)

5:2=2 (1)

2:2=1 (0)

34510=1010110012

ΙΙ 0.876*2=1.752 (1)

0.752*2=1.504 (1)

0.504*2=1.008 (1)

0.008*2=0.016 (0)

0.016*2=0.032 (0)

0.032*2=0.064 (0)

0.064*2=0.128 (0)

0.128*2=0.256 (0)

0.256*2=0.512 (0)

0.512*2=1.024 (1)

0.024*2=0.048 (0)

0.048*2=0,096 (0)

0.096*2=0.192 (0)

0.192*2=0.384 (0)

0.384*2=0.768 (0)

0.8672=111000000100000

Формирую число

А2=101011001.111000000100000


Привожу число к необходимому виду

А2=1.01011001111000000100000 *10-8

Работая с порядком десяти

P=127-8=11910

119:2=59 (1)

59:2=29 (1)

29:2=14 (1)

14:2=7 (0)

7:2=3 (1)

3:2=1 (1)

Р2=01110111

А2=1.01011001111000000100000*10011101112

Заполняю разрядную сетку IEEE формата

А=00111011101011001111000000100000

Знак Степень Метиса

Ответ:00111011101011001111000000100000

4.) Определить, попадает ли точка с произвольно заданными координатами (х, у) в заштрихованную область. Точки х, у задать самостоятельно.


Задача сводится к нахождению пределов выделенной области. Для облегчения этой задачи я разделил график на две части.

Функция f1 лежащая выше оси Oy является формулой полуокружности, при у>0.

(x-x0)2+(y-y0)2≤r2 ,

где r-радиус.

(x+1)+y2≤1

y2≤1-(x+1)2

y≤+

2

Точка попадёт в область f1 при:

у>0

y≤+

2

Фигура f2 лежащая ниже оси Oy является прямоугольником, при y<0

Точка попадёт в область f1 при:


y≤0

y>-0.5

x≥-2

x≤0

Для упрощения алгоритма ввожу логические переменные , принимающие значения истина или ложь.

L1= y≤+

2 и у>0

L2= x≥-2 и x≤0 и y>-0.5 и y≤0

Блок-схема


-+


5.) Пусть a1=b1=1; ak = 3∙ bk-1 + 2∙ ak-1; bk = 2∙ ak-1 + bk-1, k = 2,3, …

Дано натуральное число n. Вычислить

Задача сводится к накоплению суммы из выражений содержащих члены.

S=S+x , где ак и вк описываются как одномерные статистические массивы, а к! будет описан с помощью переменной F.

Первый член ряда равен:

X1=2/(1+1+1)*1=2/3

Цикл начинаю со второго элемента. Для избавления от бесконечного цикла, ввожу ограничение для предела к (n).


-




6.) Разработать алгоритм обработки одномерных числовых массивов. Массивы задать самостоятельно, предусмотреть печать всех результатов.