Рефетека.ру / Информатика и програм-ие

Лабораторная работа: Сложение и вычитание целых неотрицательных чисел в двоичном коде

Министерство образования Республики Таджикистан

Таджикский Технический Университет им. ак. М. С. Осими

кафедра АСОИиУ


Лабораторная работа №2


«Сложение и вычитание целых неотрицательных чисел в двоичном коде»


Выполнил:


Принял:


-Душанбе 2009-


Программа «Plusdouble»


Option Explicit

Public sel As Integer

Public i, x, j, x0 As Double

Public c As Integer


Сложение и вычитание целых неотрицательных чисел в двоичном коде


Окно приложения в исходном состоянии.


Сложение и вычитание целых неотрицательных чисел в двоичном кодеPrivate Sub Command1_Click()

fir.Text = ""

sec.Text = ""

res.Text = ""

x = 0

j = 0 Процедура очистки полей формы

x0 = 0

i = 0

End Sub


Сложение и вычитание целых неотрицательных чисел в двоичном коде

Private Sub ext_Click()

End Процедура выхода

End Sub


Сложение и вычитание целых неотрицательных чисел в двоичном кодеPrivate Sub fir_Change()

If val(fir.Text) = 0 Or val(fir.Text) = 1 Then

lb1.Caption = fir.Text

Exit Sub

Else

i = (Len(fir.Text))

x = 0

j = 0

Do Процедура для перевода

x = x + (val(Mid(fir.Text, i, 1)) * (2 ^ j)) введённого значения

i = i – 1 в десятичный код

j = j + 1

Loop Until i = 0

lb1.Caption = x

End If

End Sub


Private Sub fir_GotFocus()

sel = 1

End Sub


Сложение и вычитание целых неотрицательных чисел в двоичном кодеPrivate Sub Form_KeyDown(KeyCode As Integer, Shift As Integer)

On Error GoTo err:

If (KeyCode = vbKeyBack) Then

Select Case sel

Case 1

fir.Text = Left(fir.Text, Len(fir.Text) - 1)

Case 2

sec.Text = Left(sec.Text, Len(sec.Text) - 1)

End Select

Else

End If

Exit Sub

err:

Beep

End Sub


Private Sub Form_KeyPress(KeyAscii As Integer)

Dim val As String

val = Chr(KeyAscii)

If (val >= "0") And (val <= "9") Then

If sel = 1 Then

Select Case val

Case "0"

fir.Text = fir.Text & "0"

Case "1" Процедуры

fir.Text = fir.Text & "1" контроля за

End Select вводом

ElseIf sel = 2 Then

Select Case val

Case "0"

sec.Text = sec.Text & "0"

Case "1"

sec.Text = sec.Text & "1"

End Select

Else

End If

Else

End If

End Sub

Private Sub Form_Load()

plus.Value = True

c = 1

End Sub


Сложение и вычитание целых неотрицательных чисел в двоичном коде


Форма с введёнными значениями

Private Sub res_Change()

If val(res.Text) = 0 Or val(res.Text) = 1 Then

lb3.Caption = res.Text

Exit Sub

Else

i = (Len(res.Text))

x = 0

j = 0

Do

x = x + (val(Mid(res.Text, i, 1)) * (2 ^ j))

i = i - 1

j = j + 1

Loop Until i = 0

lb3.Caption = x

End If

End Sub


Private Sub res_GotFocus()

sel = 3

End Sub


Private Sub run_Click()

Dim d(90) As Integer

If fir.Text = "" Or sec.Text = "" Then

MsgBox "Incorrect input. Please input numbers again", , "=VaMp1r3=™"

Exit Sub

Else

Select Case plus.Value

Case True

x0 = ((CInt(lb1.Caption)) + (CInt(lb2.Caption)))

x = 0

c = 1

Do

d(c) = x0 Mod 2

x = Round((CDbl(x0) / 2) - 0.3, 0)

c = c + 1

x0 = x

Loop Until x = 1

d(c) = x

res.Text = ""

Do

res.Text = res.Text & d(c)

c = c - 1

Loop Until c = 0

Case False

If val(lb2.Caption) > val(lb1.Caption) Then

MsgBox "Так нельзя! Первое слагаемое должно быть больше второго. , "=VaMP1r3=™"

Exit Sub

Else

x0 = ((CInt(lb1.Caption)) - (CInt(lb2.Caption)))

x = 0

c = 1

Do

If x0 = 0 Then Exit Do

d(c) = x0 Mod 2

x = Round((CDbl(x0) / 2) - 0.3, 0)

c = c + 1

x0 = x

Loop Until x = 1

d(c) = x

res.Text = ""

Do

res.Text = res.Text & d(c)

c = c - 1

Loop Until c = 0

End If

End Select

End If

End Sub


Сложение и вычитание целых неотрицательных чисел в двоичном коде


Форма с вычисленными данными


Private Sub sec_Change()

If val(sec.Text) = 0 Or val(sec.Text) = 1 Then

lb2.Caption = sec.Text

Exit Sub

Else

i = (Len(sec.Text))

x = 0

j = 0

Do

x = x + (val(Mid(sec.Text, i, 1)) * (2 ^ j))

i = i - 1

j = j + 1

Loop Until i = 0

lb2.Caption = x

End If

End Sub


Private Sub sec_GotFocus()

sel = 2

End Sub

Похожие работы:

  1. ... операции сложения и вычитания в прямом двоичном коде
  2. • Арифметические устройства
  3. • Арифметические основы ЦВМ
  4. • Умножение и деление целых неотрицательных чисел в ...
  5. • Арифметические основы ЦВМ
  6. • Числовая и нечисловая обработка информации
  7. • Методика обучения математике как учебный предмет. Принципы ...
  8. • Деление двоичных чисел в прямом, обратном и ...
  9. • Способы кодирования информации и порядок преобразования ...
  10. • Преобразователь двоичного кода от 0 до 255 в ...
  11. • Блок сложения двоичных чисел
  12. • Формирование понятия свойств арифметических действий ...
  13. • ЯЗЫК МАКРОАССЕМБЛЕРА IBM PC
  14. • Лаба по информатике
  15. • IBM PC
  16. • Последовательный 16-ти разрядный сумматор
  17. • Перевод целых неотрицательных чисел в различных ...
  18. • Программа перевода десятичного числа в двоичную и ...
  19. • Разработка системы телемеханики
Рефетека ру refoteka@gmail.com