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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 14, средняя оценка - 4.79
Заколебал ты
0 / 0 / 0
Регистрация: 19.03.2012
Сообщений: 7
19.03.2012, 17:29     Представление float в двоичной системе #1
Смысл: требуется написать программу, показывающую двоичную структуру 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; 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Nameless One
Эксперт С++
 Аватар для Nameless One
5754 / 3403 / 255
Регистрация: 08.02.2010
Сообщений: 7,393
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
Эксперт С++
 Аватар для Nameless One
5754 / 3403 / 255
Регистрация: 08.02.2010
Сообщений: 7,393
24.03.2012, 01:42     Представление float в двоичной системе #4
youfuckmedown, ошибка в том, что нужно использовать объединение, а вместо этого ты делаешь что-то бессмысленное
Заколебал ты
0 / 0 / 0
Регистрация: 19.03.2012
Сообщений: 7
24.03.2012, 01:42  [ТС]     Представление float в двоичной системе #5
да, я уже поняла исправлено все работает)
Yandex
Объявления
24.03.2012, 01:42     Представление float в двоичной системе
Ответ Создать тему
Опции темы

Текущее время: 16:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru