stringtranslate.com

Метод дополнений

Дополнительные числа на арифмометре , ок. 1910 г. Меньшие числа, используемые при вычитании, являются дополнением до девяти больших чисел, которые используются при сложении.

В математике и вычислениях метод дополнений — это метод кодирования симметричного диапазона положительных и отрицательных целых чисел таким образом, что они могут использовать один и тот же алгоритм (или механизм ) для сложения во всем диапазоне. Для заданного числа мест половина возможных представлений чисел кодируют положительные числа, другая половина представляет их соответствующие аддитивные обратные числа . Пары взаимно аддитивных обратных чисел называются дополнениями . Таким образом, вычитание любого числа реализуется путем прибавления его дополнения. Изменение знака любого числа кодируется путем генерации его дополнения, что может быть выполнено с помощью очень простого и эффективного алгоритма. Этот метод обычно использовался в механических калькуляторах и до сих пор используется в современных компьютерах . Обобщенная концепция дополнения основания (как описано ниже) также ценна в теории чисел , например, в теореме Миди .

Дополнение до девяти числа, заданного в десятичном представлении, образуется путем замены каждой цифры на девять минус эта цифра. Чтобы вычесть десятичное число y ( вычитаемое ) из другого числа x ( уменьшаемое ), можно использовать два метода:

В первом методе дополнение x до девяти добавляется к y . Затем формируется дополнение полученного результата до девяти для получения желаемого результата.

Во втором методе дополнение y до девяти добавляется к x , а к сумме добавляется единица. Затем самая левая цифра '1' результата отбрасывается. Отбрасывание самой левой '1' особенно удобно на калькуляторах или компьютерах, которые используют фиксированное количество цифр: ее некуда девать, поэтому она просто теряется во время вычислений. Дополнение до девяти плюс один известно как дополнение до десятков.

Метод дополнений может быть распространен на другие системы счисления ( радике ); в частности, он используется на большинстве цифровых компьютеров для выполнения вычитания, представления отрицательных чисел в двоичной или двоичной арифметике и проверки переполнения при вычислениях. [1]

Числовые дополнения

Дополнение по основанию -значного числа в системе счисления определяется как . На практике дополнение по основанию проще получить, прибавив 1 к уменьшенному дополнению по основанию , которое равно . Хотя это кажется столь же сложным для вычисления, как и дополнение по основанию, на самом деле это проще, поскольку это просто цифра, повторенная раз. Это потому, что (см. также Формула геометрической прогрессии ). Зная это, уменьшенное дополнение по основанию числа можно найти, дополняя каждую цифру относительно , ​​т.е. вычитая каждую цифру из .

Вычитание из с использованием уменьшенных дополнений к основанию может быть выполнено следующим образом. Добавьте уменьшенное дополнение к основанию к , чтобы получить или эквивалентно , которое является уменьшенным дополнением к основанию . Дальнейшее взятие уменьшенного дополнения к основанию приводит к желаемому ответу .

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

В десятичной системе счисления дополнение по основанию называется дополнением до десятков , а уменьшенное дополнение по основанию — дополнением до девяток . В двоичной системе счисления дополнение по основанию называется дополнением до двух , а уменьшенное дополнение по основанию — дополнением до единиц . Названия дополнений в других системах счисления аналогичны. Некоторые люди, в частности Дональд Кнут , рекомендуют использовать размещение апострофа для различения дополнения по основанию и уменьшенного дополнения по основанию. В этом использовании дополнение по основанию до четырех относится к дополнению по основанию числа в системе счисления с основанием четыре, в то время как дополнение по основанию до четырех — это уменьшенное дополнение по основанию числа в системе счисления с основанием пять. Однако это различие неважно, когда основание очевидно (почти всегда), и тонкое различие в размещении апострофа не является общепринятой практикой. Большинство авторов используют дополнение по единице и дополнение по девятке , и многие руководства по стилю опускают апостроф, рекомендуя дополнение по единице и дополнению по девятке .

Пример десятичного числа

Дополнение до девяти десятичной цифры — это число, которое нужно к ней прибавить, чтобы получить 9; дополнение до девяти 3 — это 6, дополнение до девяти 7 — это 2 и т. д., см. таблицу. Чтобы сформировать дополнение до девяти большего числа, каждая цифра заменяется своим дополнением до девяти.

Рассмотрим следующую задачу на вычитание:

 873 [x, уменьшаемое]- 218 [y, вычитаемое]

Первый метод

Вычислите дополнение уменьшаемого числа до девяти, 873. Добавьте это к вычитаемому 218, затем вычислите дополнение результата до девяти.

 126 [дополнение x до девяти = 999 - x]+ 218 [y, вычитаемое]————— 344 [999 - х + у]

Теперь вычислите дополнение результата до девяти.

 344 [результат] 655 [дополнение до девяти числа 344 = 999 - (999 - x + y) = x - y, правильный ответ]

Второй метод

Вычислите дополнение до девяти числа 218, которое равно 781. Поскольку число 218 состоит из трех цифр, это то же самое, что вычесть 218 из 999.

Далее берется сумма и дополнение до девяти :

 873 [х]+ 781 [дополнение y до девяти = 999 - y]————— 1654 [999 + х - у]

Затем первая цифра «1» отбрасывается, и получается 654.

1654-1000 [-(999 + 1)]————— 654 [-(999 + 1) + 999 + х - у]

Это пока не верно. На первом этапе к уравнению было добавлено 999. Затем 1000 было вычтено, когда была отброшена ведущая 1. Таким образом, полученный ответ (654) на единицу меньше правильного ответа . Чтобы исправить это, к ответу добавляется 1:

 654+ 1————— 655 [х - у]

Добавление 1 дает 655, правильный ответ на нашу исходную задачу на вычитание. Последний шаг добавления 1 можно было бы пропустить, если бы вместо этого на первом шаге использовалось дополнение y до десятков.

Величина чисел

В следующем примере результат вычитания имеет меньше цифр, чем :

 123410 [x, уменьшаемое]- 123401 [y, вычитаемое]

Используя первый метод, сумма девяток-дополнений чисел и равна

 876589 [дополнение x до девяти]+ 123401 [г]———————— 999990

Дополнение числа 999990 до девяти равно 000009. Удаление начальных нулей дает 9 — желаемый результат.

Если вычитаемое, , имеет меньше цифр, чем уменьшаемое, , во втором методе необходимо добавить ведущие нули. Эти нули становятся ведущими девятками, когда берется дополнение. Например:

 48032 [х]- 391 [г]

можно переписать

 48032 [х]- 00391 [y с ведущими нулями]

Замена 00391 его дополнением до девяти и добавление 1 дает сумму:

 48032 [х]+ 99608 [дополнение y до девяти]+ 1——————— 147641

Отбрасывая первую цифру 1, получаем правильный ответ: 47641.

Двоичный метод

Метод дополнений особенно полезен в двоичной системе счисления (основание 2), поскольку дополнение до единиц очень легко получить путем инвертирования каждого бита (изменение '0' на '1' и наоборот). Добавление 1 для получения дополнения до двух можно выполнить путем имитации переноса в младший бит. Например:

 0110 0100 [x, равно десятичному 100]- 0001 0110 [y, равно десятичному 22]

становится суммой:

 0110 0100 [х]+ 1110 1001 [дополнение y до единицы = 1111 1111 - y]+ 1 [чтобы получить дополнение до двух = 1 0000 0000 - y]——————————— 10100 1110 [х + 1 0000 0000 - у]

Отбрасывая начальную «1», получаем ответ: 0100 1110 (равняется десятичному 78)

Представление отрицательных чисел

Метод дополнений обычно предполагает, что операнды положительны и что yx , логические ограничения, учитывая, что сложение и вычитание произвольных целых чисел обычно выполняется путем сравнения знаков, сложения двух чисел или вычитания меньшего из большего и присвоения результату правильного знака.

Давайте посмотрим, что произойдет, если x < y . В этом случае не будет цифры "1", которую нужно будет вычеркнуть после сложения, так как будет меньше . Например, (в десятичной системе):

 185 [х]- 329 [г]

Дополнение y и добавление дает:

 185 [х]+ 670 [дополнение y до девяти]+ 1————— 856

На этом этапе нет простого способа завершить вычисления вычитанием (в данном случае 1000); нельзя просто игнорировать ведущую 1. Ожидаемый ответ — −144, что не так уж и далеко, как кажется; 856 — это десятичный дополнительнй код числа 144. Эту проблему можно решить несколькими способами:

Практическое использование

Комптометр 1920-х годов с девятками, отмеченными на каждой клавише

Метод дополнений использовался во многих механических калькуляторах как альтернатива обратному ходу шестеренок. Например:

В компьютерах

Использование метода дополнений повсеместно в цифровых компьютерах, независимо от представления, используемого для знаковых чисел. Однако требуемая схема зависит от представления:

Ручное использование

Метод дополнений использовался для исправления ошибок, когда бухгалтерские книги писались вручную. Чтобы удалить запись из столбца чисел, бухгалтер мог добавить новую запись с дополнением до десятков числа, которое нужно было вычесть. Над цифрами этой записи добавлялась черта, чтобы обозначить ее особый статус. Затем можно было сложить весь столбец цифр, чтобы получить исправленный результат.

Дополнение суммы удобно для кассиров, выдающих сдачу за покупку валюты в едином номинале 1, возведенном в целую степень основания валюты. Для десятичных валют это будет 10, 100, 1000 и т. д., например, купюра в 10 долларов.

В начальной школе

В начальных школах ученикам иногда преподают метод дополнений как полезный метод ментальной арифметики . [3] Вычитание выполняется путем прибавления десятичного дополнения вычитаемого , которое является девятичным дополнением плюс 1. Результат этого сложения используется, когда ясно, что разница будет положительной, в противном случае используется десятичный дополнения результата сложения, помеченный как отрицательный. Тот же метод работает для вычитания на арифмометре.

Смотрите также

Ссылки

  1. ^ Флоридский технологический институт
  2. ^ Простые инструкции по эксплуатации управляемого ключевого комптометра, Comptometer Division, Felt and Tarrant Mfg. Co., Чикаго, 1917, стр. 12
  3. ^ Карл Барнетт Аллендорфер (1971). Принципы арифметики и геометрии для учителей начальной школы . Macmillan.