Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.51/51: Рейтинг темы: голосов - 51, средняя оценка - 4.51
 Аватар для Millen
0 / 0 / 0
Регистрация: 21.11.2010
Сообщений: 17

двоичное представление

23.11.2010, 23:57. Показов 9749. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
пользователь вводит с клавиатуры 2 беззнаковых длинных целых числа a, b. Вывести на консоль слагаемые и их сумму a+b в двоичной системе.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
unsigned long bin(unsigned long x)
{
    for(int i = 31; i >= 0; --i)
        printf("%d", (x>>i) & 1);
    return (x);
}
 
int _tmain(int argc, _TCHAR* argv[])
{unsigned long ch,ch1,sum;
 setlocale(0,""); 
  printf("Введите число a = "); 
scanf_s("%u", &ch);
printf("Двоичное представление a:\n") ;
    bin(ch);
  printf("\nВведите число b = "); 
scanf_s("%u", &ch1);
printf("Двоичное представление b:\n") ;
    bin(ch1);
printf("\nДвоичное представление a + b :\n") ;
    sum=ch+ch1;
       bin(sum);
    return 0;
}
но при сложении, к примеру 4000000000 + 4000000001, теряется вначале 1. что делать? и можно ли при выводе избавиться от нулей спереди?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.11.2010, 23:57
Ответы с готовыми решениями:

Двоичное представление
Народ! Помогите пожалуйста! Каким образом работает эта функция? void BinOut(unsigned char* Buf,int len){ int i,j; ...

Двоичное представление символов
Проблема такая: я прогаю скремблер, и проблема в том, что буквы при переводе дают семизначное двоичное число, а символы - шестизначное. И...

Двоичное представление double
Есть программа, которая переводит число DOUBLE в двоичный код по стандарту IEEE 754, но выводит его в обратном порядке. Почему? union...

7
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
24.11.2010, 01:23
C
1
scanf_s("%u", &ch);
C
1
scanf("%lu", &ch);
Добавлено через 2 минуты
4000000000 + 4000000001
ты не можешь складывать такие числа, результат не влезет в unsigned long int (если sizeof(unsigned long) == 4)
0
 Аватар для Millen
0 / 0 / 0
Регистрация: 21.11.2010
Сообщений: 17
24.11.2010, 10:54  [ТС]
Цитата Сообщение от accept Посмотреть сообщение
, результат не влезет в unsigned long int
насколько я понял задача и заключается для тех чисел, что не влезут. вопрос в том, в каком случае будет нужна единица слева.
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
24.11.2010, 11:44
про какую еденицу слева идёт речь ?
когда число не влазит в unsigned long, оно делится на максимальное число, которое помещается в unsigned long плюс один, и тот остаток от деления, который получается, и является результатом операции

8,000,000,001 % (2 ^ 32) = 3,705,032,705
0
 Аватар для Millen
0 / 0 / 0
Регистрация: 21.11.2010
Сообщений: 17
25.11.2010, 22:10  [ТС]
Получается и как должно быть
Миниатюры
двоичное представление   двоичное представление  
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
25.11.2010, 22:52
8000000001 == 1 1101 1100 1101 0110 0101 0000 0000 0001

Цитата Сообщение от Millen
Получается и как должно быть
функция, выводящая 32 бита, выводит 33 бита ?
0
 Аватар для Millen
0 / 0 / 0
Регистрация: 21.11.2010
Сообщений: 17
25.11.2010, 23:09  [ТС]
Нет, это из этой программы
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#include "stdafx.h"
#include <iostream>
using namespace std;
int bin1[32],bin2[32],length,i;
void binary(unsigned long int x, int bin[32]);
int _tmain(int argc, _TCHAR* argv[])
{   unsigned long int  a,b,length0;
    int bin3[33];
    printf("input  a, b\n");
    scanf_s("%u", &a);
    scanf_s("%u", &b);
    length0=a+b;
    printf("a=");
    binary(a,bin1);
    printf("b=");
    binary(b,bin2);
    int k=0,j=32;
    for (i=31; i>=0; i--)
    {
        if (bin1[i]+bin2[i]+k==3)
        {
            bin3[j]=1;
            k=1;
        }
            else 
                if (bin1[i]+bin2[i]+k==2)
                {
                    bin3[j]=0;
                    k=1;
                }
                    else 
                        if (bin1[i]+bin2[i]+k==1)
                        {
                            bin3[j]=1;
                            k=0;
                        }
                            else 
                            {
                                bin3[j]=0;
                                k=0;    
                            }
            
        
        j=j-1;
        if (j==0)
            bin3[0]=k;
    }
 
    i=0;
    length=0;
    while (bin3[i]<1)
    { 
        length++;
        i++;
    }
    if (length0==0)
        length=32;
    printf("sum=");
    for(i=length; i<33; i++)
        printf("%i", bin3[i]);
    printf("\n");
    return 0;
}
void binary(unsigned long int x, int bin[32])
{ 
    int length;
    if (x<2)
    {
        bin[31]=x;
        length=31;
    }
        else 
        {
            int i=31;
            do
            {
                bin[i]=x%2;
                x=x/2;
                i=i-1;
            }
            while (x>1);
            bin[i]=x;
            length=i;
        }
        for(int i=length; i<32; i++)
            printf("%i", bin[i]);
        printf("\n");
}
но нужно сделать с помощью побитовых операций.
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
26.11.2010, 02:16
у тебя задание, по ходу, без учёта этого переполнения
достаточно сделать проверку на ввод допустимых чисел
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.11.2010, 02:16
Помогаю со студенческими работами здесь

Двоичное представление числа
Введите целое положительное N и выведите его двоичное представление. Ниже представлен код, но он выводит число на оборот (то есть если...

Двоичное представление типов данных
Всем привет. Не могли бы вы мне помочь пожалуйста с такой задачей на С++: необходимо на экран выдать двоичное представление переменной...

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

Двоичное представление символов ASCII
например дана последовательность: 0110100001101001 где h=01101000 i=01101001 ] numeric=0110100001101001 как сделать что то вроде...

Двоичное представление числа (побитовые операторы)
Помогите решить 2 задачи: 1) Человек вводит целое число. Вывести на экран двоичное представление числа через побитовые операторы. 2)...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru