
Создание программы C++ для двоичного вычитания
23 февраля 2022 г.Введение
Двоичные числа — это числа, цифры которых состоят из 0 и 1. Двоичное вычитание — это одна из четырех арифметических операций, в которых мы выполняем метод вычитания двух двоичных чисел. Операция очень похожа на арифметическое вычитание.
Когда мы выполняем двоичное вычитание и вычитаем 1 из 0, мы должны заимствовать 1 из следующей цифры более высокого порядка, чтобы уменьшить ее на 1, и в этом случае остаток остается 1.
Двоичные операции вычитания
Ниже приведены некоторые основные операции, выполняемые при вычитании двух двоичных чисел.
- 0 – 0 = 0
- 1 – 0 = 1
- 1 – 1 = 0
- 0 – 1 = 1 (Заимствовать 1 из следующей старшей цифры)
Методы вычитания двоичных чисел
Существует несколько способов вычитания [двоичных чисел] (https://hackernoon.com/an-essential-guide-to-binary-representation-of-floating-point-numbers-uw2n37tc). Некоторые из них следующие:
А. Обычное вычитание путем заимствования из старшей цифры
Возьмите два числа, например 1010 и 101.
1 0 1 0
- 1 0 1
- Начиная с последней цифры, вычитаем (0 - 1). Нам нужно позаимствовать 1 из другого столбца, поэтому после заимствования 1 оно становится (10 - 1), что приводит к 1.
1 0 1 0
- 1 0 1
1
- На месте десятков у нас остается (0 - 0), что дает 0.
1 0 1 0
- 1 0 1
- В разряде 100 заимствуем 1 из разряда 1000. После выполнения операции (10-1) мы получаем 1 на 1000 разряде.
1 0 1 0
- 1 0 1
1 0 1
- На месте 1000 у нас остался только 0, поэтому на выходе этой подстанции получается 0101. Мы можем перепроверить это, так как 1010 в десятичном виде равно 10, а 101 равно 5. Итак, 10 - 5 = 5 ( 0101 в двоичный)
1 0 1 0
- 1 0 1
0 1 0 1
B. Двоичное вычитание с использованием дополнения до 1
Мы можем вычесть два числа, используя дополнение до 1. Следующие шаги должны быть выполнены -
- Запишите дополнение вычитаемого до единицы.
- Добавьте это дополнение к уменьшаемому.
- Если результат содержит перенос, добавьте его к младшему значащему биту.
- Если переноса нет, возьмите дополнение до 1 результата и его отрицательное значение.
Возьмем два числа 110101(53) и 100101(37).
1 1 0 1 0 1
- 1 0 0 1 0 1
Здесь 37 — вычитаемое. Дополнение 37 до единицы - 011010
Добавляя его с minuend.
1 1 0 1 0 1
+ 0 1 1 0 1 0
10 0 1 1 1 1
Здесь 1 — перенос. Теперь мы добавляем это 1 к результату.
1 0 0 1 1 1 1
- 1
0 1 0 0 0 0
В результате получается 010000, что равно 16 в десятичном формате.
С. Двоичное вычитание с использованием дополнения до двух
Чтобы выполнить [бинарное вычитание] (https://www.scaler.com/topics/binary-subtraction/) с использованием дополнения до двух, необходимо выполнить следующие шаги:
- Найдите дополнение до двух вычитаемого.
- Добавьте дополнение к этим двум с уменьшаемым окончанием.
- Отбросьте бит переноса, если он есть, а остальное - ответ.
- В случае отсутствия переноса возьмите дополнение до двух от результата, который будет отрицательным.
Возьмем два числа 10101(21) и 00111(7). Вычисление дополнения до двух вычитаемого.
0 0 1 1 1 = 1 1 0 0 1 (в дополнении до 2)
Добавляя его к minuend,
1 0 1 0 1
+ 1 1 0 0 1
1 0 1 1 1 0
Мы получаем 1, поэтому отбрасываем его, и окончательный ответ приходит к 01110(14).
Программа C++ для выполнения двоичного вычитания
```javascript
include
include<бит/stdc++.h>
использование пространства имен std;
// Программа для вычитания двух двоичных чисел
Вычитание недействительный (Int N, Int А [], Int Ь [])
// Дополнение вычитаемого до 1
for(int i = 0; i < n; i++)
//Заменяем 1 на 0
если (Ь [я] == 1)
б [я] = 0;
// Заменить 0 на 1
еще
б [я] = 1;
//Добавить 1 в конце, чтобы получить дополнение до 2 вычитаемого
for(int i = n - 1; i >= 0; i--)
если (б [я] == 0)
б [я] = 1;
перерыв;
еще
б [я] = 0;
// Представляет перенос
инт = 0;
for(int i = n - 1; i >= 0; i--)
// Добавляем a, b и переносим
а[я] = а[я] + б[я] + т;
// Если a[i] равно 2
если (а [я] == 2)
а[я] = 0;
т = 1;
// Если a[i] равно 3
иначе если (a[i] == 3)
а[я] = 1;
т = 1;
еще
т = 0;
cout << конец;
// Если перенос сгенерирован
// отбросить перенос
если (т == 1)
// распечатать результат
for(int i = 0; i < n; i++)
// Печать результата
cout<<a[i];
// если перенос не сгенерирован
еще
// Вычисление дополнения до 2
// полученного результата
for(int i = 0; i < n; i++)
если (а [я] == 1)
а[я] = 0;
еще
а[я] = 1;
for(int i = n - 1; i >= 0; i--)
если (а [я] == 0)
а[я] = 1;
перерыв;
еще
а[я] = 0;
// Добавляем знак -ve для представления
cout << "-";
// -ve результат
// Печатаем результирующий массив
for(int i = 0; i < n; i++)
cout << а[i];
int main() // Основная функция
инт н;
п = 5;
int а [] = {1, 0, 1, 0, 1},
б[] = {0, 0, 1, 1, 1};
Вычесть (п, а, б);
вернуть 0;
Выход:
```javascript
Временная сложность - O(nlogn)
Пространственная сложность - O(1)
Заключение
Мы можем вычесть два двоичных числа, используя три метода — простое вычитание, с использованием дополнения до 1 и с использованием дополнения до 2.
При простом вычитании мы заимствуем бит из следующего старшего значащего бита.
В дополнении до 1 мы выполняем дополнение до 1 вычитаемого и прибавляем его к уменьшаемому. Если есть перенос, добавьте его к последнему биту, в противном случае возьмите дополнение результата до 1.
В случае вычитания дополнения до двойки возьмите дополнение до двойки вычитаемого и прибавьте его к уменьшаемому. Если есть перенос, отбросьте его, иначе возьмите два дополнения к результату, что приведет к отрицательному ответу**.**
Оригинал
Recent Post
-
Как работают хеш -карты
7 августа 2025 г. -
Повышение производительности разработчика: секрет укрощения повторяющегося кода
5 августа 2025 г. -
Как я приземлился на первом клиенте на полпути через проект ODIN
21 июля 2025 г. -
5 гениальных структур данных (и что они на самом деле делают)
18 июня 2025 г. -
Разрушение учебной программы проекта ODIN в проекте - по одному проекту за раз
18 июня 2025 г.
Categories
- Python
- blockchain
- web
- hackernoon
- вычисления
- вычислительные компоненты
- цифровой дом
- игры
- аудио
- домашний кинотеатр
- Интернет
- Мобильные вычисления
- сеть
- фотосъемка видео
- портативные устройства
- программного обеспечения
- телефон и связь
- телевидение
- видео
- мир технологий
- умные гиды
- облако
- искусственный интеллект
- се
- Samsung
- умные города
- digitaltrends
- отели
- Startups
- Venture
- Crypto
- Apps
- безопасность
- техника и работа
- cxo
- мобильность
- разработчик
- 5г
- майкрософт
- инновации
- Права и свободы
- Законодательство и право
- Политика и общество
- Космическая промышленность
- Информационные технологии
- Технологии
- Образование
- Научные исследования
- Автомобильная промышленность
- Программная инженерия
- IT и технологии
- Веб-разработка
- Программирование
- Автоматизация
- Карьерный рост
- Программирование и анализ данных
- Трудоустройство
- Политика
- Искусственный интеллект
- ИТ-технологии
- Программное обеспечение
- Экологическая политика
- Образование и рынок труда
- Политика и право
- Microsoft Teams и SharePoint
- Информационная безопасность
- Кибербезопасность
- Налоги
- Образование и карьера
- Интернет и технологии
- Технологии, Государственные услуги
- Политика и технологии
- Разработка программного обеспечения
- Разработка ПО
- Машинное обучение
- Налогообложение, технологии, открытый исходный код
- Финансы и налоги
- Технологии, Интернет, Экология
- Интернет, безопасность
- Технологии и политика
- Операционные системы
- Профессиональная разработка
- Технологии, Безопасность
- Интернет и общество
- Финансовая индустрия
- Налоговый учёт
- Общественное здравоохранение
- Технологическая отрасль
- Юриспруденция
- Технологии и государство
- Здоровье и фитнес
- IT-инфраструктура
- Технологии и ИИ
- Здравоохранение
- IT
- Технологии, Экономика
- Музыка и технологии
- Здоровье и питание
- IT и безопасность
- Бизнес и предпринимательство
- Технологии, Программное обеспечение
- Технологии и инновации
- Технологии, данные, этика
- Технологии и Интернет
- Технологии и SaaS
- Медицина и здравоохранение
- Онлайн-видеосервисы
- Финансы и технологии
- Чтение и саморазвитие
- Экономика и бизнес
- Безопасность данных
- Удаленная работа
- Авиация и технологии
- Технологии, Игры
- Энергетика
- Социальные сети, безопасность, технологии
- Саморазвитие
- Безопасность информации
- Бизнес и карьера
- Технологии и отношения
- Игровая индустрия
- Компьютерная индустрия
- Математика, Искусственный интеллект
- Наука и технологии
- Технологии и безопасность
- Технологии, Удаленная работа, Бизнес
- Видеоигры
- Технологии, Искусственный интеллект, Этика
- Технологии, социальные сети, 6G
- Технологии, Программирование, AI, Разработка ПО
- Программирование, Разработка ПО, Технологии
- Животные
- Технологии, Искусственный интеллект
- Программирование, карьера, технологии, обучение
- Бизнес и технологии
- Технологии, Безопасность данных
- Астрономия и физика
- Продуктивность, личное развитие
- Медиа и Технологии
- Программирование и Искусственный Интеллект
- Социальные сети
- Политика и экономика
- Технологии, Медицина, Искусственный интеллект
- Технологии и управление
- Космос и астрономия
- Общество и политика
- Космические исследования
- Веб-дизайн
- Искусственный интеллект и безопасность данных
- Технологии, Безопасность, Конфиденциальность
- Экологическая проблема
- Технологии, Погода
- Авиация
- Транспортная сфера
- Технологии и бизнес
- Игровая промышленность
- Телевидение и реклама
- Аналитика данных
- Технологии и кибербезопасность
- Маркетинг
- Технологии и гаджеты
- Технологии, Авиация, Инновации
- Финансы и инвестиции
- Технологии и общество
- Рыночный анализ
- Космология
- Данные и бизнес
- IT и программирование
- Технологии и право
- Программирование и разработка
- Астрофизика
- Медицинские технологии
- Авиационная промышленность
- Технологии и искусственный интеллект
- Генетическая инженерия
- Бизнес и инвестиции
- Компьютерная промышленность
- Психология и социология
- Образование и технологии
- Рынок труда
- Технологии, Стартапы
- Технологии, Приватность, Чтение
- Маркетинг и продажи
- Виртуальная реальность
- Технологии, Смартфоны, Маркетинг
- Технологии, Бизнес, Личностный рост
- Экологические проблемы
- Экономика и технологии
- IT и карьера
- Интернет и безопасность
- Разработка и технологии
- Биотехнологии
- Интернет-магазины, кибербезопасность
- Финансы
- Безопасность и технологии
- Экономика
- Защита данных
- Data Science
- Карьера и работа
- Финансовый успех, мошенничество, маркетинг
- Безопасность
- Экология
- Космическая индустрия
- Программирование, Python, Обучение
- Технологии искусственного интеллекта
- Технологии, Дизайн, iOS
- Программирование, DevOps, Kubernetes
- Социальные сети и пропаганда
- Корпоративная этика
- Управление IT-инфраструктурой
- Здоровье и медицина
- Медицина
- Медицинская промышленность
- Разработка и дизайн
- Искусственный интеллект, Диагностика систем
- Образование и психология
- Технологии, Автомобильная промышленность
- Автомобили и путешествия
- Астрономия и космология
- Программирование и технологии
- IT, работа в офисе, эмоциональный интеллект
- Компьютерная техника
- Здоровье и благополучие
- Управление персоналом
- Политика и управление
- Бизнес и экономика
- Социальные сети, Пропаганда, Информационная безопасность
- Технологии и автоматизация
- Геймдизайн
- Экология и технологии
- CRM-системы, IT-инфраструктура
- Права человека
- Цифровая цензура, свобода слова, технологии
- Технологии, Искусственный интеллект, Работа
- Наука о данных
- Астрономия, Наука
- Интернет и цифровые технологии
- Технологии, управление
- Интернет и связь
- Технологии и конфиденциальность
- Интернет и свобода слова
- Психология и социальные науки
- Книги и литература
- Работа и карьера
- Финансовые технологии
- Психология и саморазвитие
- IT, программирование, сети
- Технологии, Видеоигры
- Экология и энергетика
- Космонавтика
- Медицина и технологии
- Игры и развлечения
- Музыкальная индустрия
- Логистика и складирование
- Бизнес и финансы
- Экология и окружающая среда
- Правозащита
- Социальные сети и дезинформация
- Технологии и рынок труда
- Технологии, Искусственный интеллект, Рынок труда
- Технологии и будущее
- Медицина и здоровье
- Социальные медиа
- Экология, политика, общество
- Экономика и Финансы
- Разработка игр
- Пропаганда и дезинформация
- Медицинские исследования
- Онлайн-знакомства
- Политика и СМИ
- Энергетика и электромобили
- Климатические изменения
- Технологии, Рынок труда
- IT и управление данными
- Безопасность и кибербезопасность
- Интернет-технологии
- Психология и личностное развитие
- Технологии, Мессенджеры
- Цифровые технологии
- Здоровье и самосовершенствование
- Технологии и AI
- Технологии и спорт
- IT, Разработка программного обеспечения
- Экология и климат
- Космос и технологии
- Юридическая сфера
- Безопасность в интернете
- Программирование, Искусственный Интеллект, Качество ПО
- Технологии и мессенджеры
- Социальная справедливость
- Технологическая индустрия
- Личностное развитие, Time-менеджмент, Психология
- Бизнес и менеджмент
- Технологии, Микросхемы, Автономные системы
- Фриланс и предпринимательство
- Социальные сети и искусственный интеллект
- Криминальные дела
- Социальные сети, Маркетинг
- Энергетика и экология
- Технологии, Искусственный Интеллект, Полиция
- Программирование, Искусственный интеллект, Рынок труда
- Социальные сети, дезинформация, анализ данных
- Потребительские права
- Образование и наука
- Технологии и правосудие
- Технологии, Безопасность, Автомобили
- Энергетика и окружающая среда
- Личностное развитие
- Технологии и экономика
- Медиа и коммуникации
- Миграция и иммиграция
- Личностный рост
- Налоговая система
- Медиа и телевидение
- Интернет и телекоммуникации
- Технологии, Кибербезопасность
- Здоровье
- Социальные сети и карьера
- Политика и инфраструктура
- Предпринимательство
- Промышленность программного обеспечения
- СМИ и коммуникации
- Медиа и Общество
- Медицина и генетика
- Веб-разработка и дизайн
- Технологии, процессоры
- IT-индустрия
- Кинопроизводство и технологии
- Транспорт
- Текстовый анализ
- Технологии, дизайн интерфейсов
- Офисные приложения
- Технологии, Онлайн-сервисы
- Медицина и биотехнологии
- Общество и технологии
- Экономика и рынок труда
- Искусственный интеллект, программирование, аналитика
- Технологии, следствие
- Сетевые технологии
- Технологии и веб-разработка
- Программирование, Обучение, Практика
- Коммуникации и ИТ
- Технологии, Карьера, Экономика
- Технологии и транспорт
- Здравоохранение и медицина
- Технологии, Государственное управление
- IT-безопасность
- IT и разработка
- Финансы и экономика
- Социальные сети, Общество, Сообщества
- IT-разработка
- СМИ и политика
- Конфиденциальность и безопасность
- Экономика и политика
- Технологии и общественная жизнь
- Бизнес и этика
- Безопасность и защита информации
- Технологии, бизнес
- Интернет и цензура
- Государственное регулирование
- Игры, Технологии
- Технологии и оптимизация
- Технологии ИИ и машинного обучения
- Технологии, IT, карьера
- IT и программное обеспечение
- Право и преступность
- Криминал и Правоохранительные Органы
- Технологии и энергетика
- Нефтяная промышленность
- Социальные конфликты
- Преступность и безопасность
- Таможенная очистка
- Медиа и журналистика
- Технологии и разработка приложений
- Телекоммуникации
- Консалтинг и управление
- Управление человеческими ресурсами
- Онлайн-контент
- Психология и психотерапия
- Морская отрасль
- Психология и технологии
- Социальные проблемы
- Маркетинг и реклама
- Политика и власть
- Экономика и торговля
- Карьера и развитие
- Продуктивность и Управление Временем
- Технологии, Искусственный интеллект, Реклама
- Окружающая среда
- Здоровье и технологии
- Бытовая химия
- Правовая информация
- Юстиция
- Технологии и экология
- Социальные сети и безопасность
- Базы данных
- Политика и государственное управление
- Интернет и социальные сети
- Индустрия IT
- Технологии и программное обеспечение
- История и искусственный интеллект
- Рестораны и обслуживание
- Технологии и программирование
- Социология
- Телевидение и СМИ
- Психология
- Политика и бизнес
- Мобильные устройства
- Технологии и развлечения
- Экология и охрана окружающей среды
- Маркетинг и брендинг
- Медицинская индустрия
- Кибербезопасность и технологии
- Социальные сети и политика
- Развлечения
- ИТ и автоматизация
- Криптовалюты и блокчейн
- История и идеология
- Медицина и политика
- Личная жизнь миллиардеров
- Образование и Политика
- Туризм и отдых
- Психология и искусственный интеллект
- Удаленная работа и производительность
- Выживание
- Управление командами
- Разработка
- Международная торговля
- Корпоративная ответственность
- Социальные сети и общество
- Управление серверами
- Индустрия компьютерных игр
- Политика и климат
- Онлайн-игры
- Медицинская отрасль
- Искусственный интеллект и технологии
- Религия и мораль
- Путешествия
- Социальные сети и информация
- Технологии и медиа
- Технологии и свобода
- Электронная коммерция
- Бизнес и управление
- Психическое здоровье и технологии
- Технологии и устойчивое развитие
- Технологии и социальные сети
- Профессии
- Экономика и промышленность
- Технологии и трудоустройство
- Иммиграционная политика
- Продуктивность и фокус
- Технологии и робототехника
- Свобода слова
- Психология и власть
- Социальные сети и онлайн-платформы
- Технологии и Права Человека
- СМИ и журналистика
- Окружающая среда и здоровье
- Технологии и сервисы
- Индустрия игр
- Программирование и ИИ
- Медиа и пропаганда
- Социальная сфера
- Социальные сети и общественное мнение
- Поп-культура
- Сервисы потокового вещания
- Рынок развлечений
- Социальные медиа и политика
- Технологии и информация
- Медиа и развлечения
- Квантовая криптография
- Искусственный интеллект в индустрии развлечений
- Технологии и коммуникация
- Индустрия программирования
- Финансовая безопасность
- Международные отношения
- Бизнес и лидерство
- Технологические новости и аналитика
- Программное обеспечение и технологии
- Предпринимательство и малый бизнес
- Политика и общественный контроль
- Здравоохранение и политика
- Управление персоналом и эффективность разработки
- Технологии и ИТ‑управление
- Свобода слова и дезинформация
- Веб-дизайн и разработка
- Веб‑разработка и карьера
- Культура и общество
- Цифровые права и свобода слова
- Безопасность и искусственный интеллект
- Технологии и искусство
- Мобильные приложения
- Продуктивность