Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 14, средняя оценка - 4.79
Заколебал ты
0 / 0 / 0
Регистрация: 19.03.2012
Сообщений: 7
#1

Представление float в двоичной системе - C++

19.03.2012, 17:29. Просмотров 1792. Ответов 4
Метки нет (Все метки)

Смысл: требуется написать программу, показывающую двоичную структуру float.
Запускаем: вводится первое число с плавающей запятой, выбираем операцию( умножение, деление, сложение, вычитание), вводим второе число с плавающей запятой - на экран выводится результат в десятичной системе и в двоичной. Моя программа выводит пока только в десятичной, потому что в двоичной как это сделать не имею никакого представления.
Маской по float нельзя, а других идей нет.
Union или указатели, может? Подскажите как они в данном случае используются.
Вот код
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
#include <iostream> 
using namespace std; 
 
int main() 
{ 
    
  float a, b; // объявление двух переменных a и b с плавающей точкой
  float c = 0.0f;
  
  char operation;
    cout << "Enter the first number: "; 
    cin >> a; 
    cout << "Enter the second number: "; 
    cin >> b; 
    cout << "Select the operation(+, -, *, /): ";
    cin >> operation;
    
    switch (operation) // начало оператора switch
    {
    case '+': 
           {
             c = a + b;
             cout << a << " + " << b << " = " << a + b << endl; // выполнить сложение
             break;
           }
    case '-': 
           {
             c = a - b;
             cout << a << " - " << b << " = " << a - b << endl; // выполнить вычитание
             break;
           }
    case '*': 
           {
             c = a * b;
             cout << a << " * " << b << " = " << a * b << endl; // выполнить умножение
             break;
           }
    case '/': 
           {
             c = a / b;
             cout << a << " / " << b << " = " << a / b << endl; // выполнить деление
             break;
           }
    default: // если operation равно любому другому значению
       cout << "Incorrect entry" << endl;
 
    }
system("pause");
 
    return 0; 
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.03.2012, 17:29     Представление float в двоичной системе
Посмотрите здесь:

Обьяснить представление числа в двоичной системе - C++
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;string.h&gt; #include &lt;iomanip&gt; #include &lt;windows.h&gt; #include...

Перевернуть число в двоичной системе и записать его десятичное представление - C++
Задание: дано десятичное число, надо перевернуть число в двоичной системе и записать его десятичное представление Помогите,...

Машинное представление типов float и struct - C++
Србственно, задача с вещестенными более-менее понятна, так как вручную все это делается более-менее легко. А вот как записать все это в...

Конвертировать машинное представление float в строку из 4 символов - C++
Допустим, есть переменная X типа float, имеющая значение... да хотя бы -3.14. Машинным представлением этого числа являются четыре байта....

Умножение в двоичной системе - C++
Добрый вечер. Помогите с реализацией умножения в двоичной системе. Дано два массива, например 1111 и 1111. Как написать цикл умножения друг...

Калькулятор в двоичной системе - C++
Сложение в двоичной системе. Подскажите почему не верные ответы выдает? #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;string&gt; ...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Nameless One
Эксперт С++
5769 / 3418 / 255
Регистрация: 08.02.2010
Сообщений: 7,446
19.03.2012, 17:53     Представление float в двоичной системе #2
Цитата Сообщение от youfuckmedown Посмотреть сообщение
Union или указатели, может?
объединения:
C++
1
2
3
4
5
union FloatRepr
{
    unsigned char bytes[sizeof(float)];
    float value;
};
Присваивай value значение, получаешь массив bytes байтов, с которыми можешь дальше работать
Заколебал ты
0 / 0 / 0
Регистрация: 19.03.2012
Сообщений: 7
23.03.2012, 21:27  [ТС]     Представление float в двоичной системе #3
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
#include <iostream> 
using namespace std; 
 
int main() 
{ 
    
  float a, b; // объявление двух переменных a и b с плавающей точкой
  float c = 0.0f;
  
  
  char operation;
    cout << "Enter the first number: "; 
    cin >> a; 
    cout << "Enter the second number: "; 
    cin >> b; 
    cout << "Select the operation(+, -, *, /): ";
    cin >> operation;
    
    switch (operation) // начало оператора switch
    {
    case '+': 
           {
             c = a + b;
             cout << a << " + " << b << " = " << a + b << endl; // выполнить сложение
             break;
           }
    case '-': 
           {
             c = a - b;
             cout << a << " - " << b << " = " << a - b << endl; // выполнить вычитание
             break;
           }
    case '*': 
           {
             c = a * b;
             cout << a << " * " << b << " = " << a * b << endl; // выполнить умножение
             break;
           }
    case '/': 
           {
             c = a / b;
             cout << a << " / " << b << " = " << a / b << endl; // выполнить деление
             break;
           }
    default: // если operation равно любому другому значению
       cout << "Incorrect entry" << endl;
    }
 
    unsigned char bytes[sizeof(float)];
    float value;  
 
union FloatRepr
    {
    unsigned char bytes[sizeof(float)];
    float value;
 
    
};
 
value = c;
cout<<bytes[sizeof(float)]<<endl;
 
 
    system("pause");
 
    return 0; 
}
не работает..
где ошибки?
Nameless One
Эксперт С++
5769 / 3418 / 255
Регистрация: 08.02.2010
Сообщений: 7,446
24.03.2012, 01:42     Представление float в двоичной системе #4
youfuckmedown, ошибка в том, что нужно использовать объединение, а вместо этого ты делаешь что-то бессмысленное
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.03.2012, 01:42     Представление float в двоичной системе
Еще ссылки по теме:

2-ичное представление числа типа double или float? - C++
помогите разобратся,,,, плиз)) double a=1991.829; a==01000000 10011111 00011111 01010000 11100101 01100000 01000001 10001001; скажите...

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

Калькулятор в двоичной системе (схемотехника) - C++
Помогите написать код для программы proteus isis Калькулятор в двоичной системе предмет схемотехника(ниже прикладываю фото схемы)и...

Вычитание чисел в двоичной системе счисления - C++
Это не подходит http://www.cyberforum.ru/cpp-beginners/thread584648.html#post3072102. Помогите написать код на с++ . А то скоро конец...

Вывод десятичных чисел в двоичной системе - C++
Заданы два числа &lt;=16. Найти их сумму и с помощью битовых операций записать оба слагаемых и их сумму одно за другим в ячейку памяти...

Сдвинуть число в двоичной системе на k позиций - C++
Нужно сдвинуть число в двоичной системе на k позиций, но проблема в том, что k может быть какое угодно большое. Можно ли стандартной...


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

Или воспользуйтесь поиском по форуму:
Заколебал ты
0 / 0 / 0
Регистрация: 19.03.2012
Сообщений: 7
24.03.2012, 01:42  [ТС]     Представление float в двоичной системе #5
да, я уже поняла исправлено все работает)
Yandex
Объявления
24.03.2012, 01:42     Представление float в двоичной системе
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru