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

Перевод из двоичной системы счисления в десятичную с плавающей запятой - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.70
Azen
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 4
25.12.2012, 11:50     Перевод из двоичной системы счисления в десятичную с плавающей запятой #1
Помогите найти ошибки в коде. Выводит не верный результат при введенных данных (11.1 или 11.01 или 11.001 и тд) неверность заключается в том, что не считает дробную часть.

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
#include <stdio.h>
#include <math.h>
#include <iostream>
#include <conio.h>
using namespace std;
 
//надеюсь вышеописанное расписывать не нужно
 
int main ()
{
    setlocale(LC_ALL, "Russian");
    cout<<"Two-position system привет to ten-position system\n";
    //Ввод числа
    cout<<"Enter digits:\n";
    double num,dr, digit;//переменные для введенного числа, дробной и целой частей
    cin>>num;//запись введенного числа
    dr = modf(num,&digit);//отделение дробной и целой частей
    int j = 0, i = 0;//счетчики
    while (fmodf(dr,1)>0)//избавление от запятой в дробной часте
        {
            dr = dr*10;
            j++;
        }
    static_cast<int>(digit);//приведем к целому типу
    static_cast<int>(dr);//приведем к целому типу
    int digitT = digit;
    int drT = dr;
    //флаговые переменные, для хранения 0 и 1, а так же для выдачи ошибки, если будет введено другое значение
    int flagCel = 1;//для целых
    int flagDr = 1;//для дробных
    //Определение числа целых разрядов
    while (digitT >= 1 && flagCel <= 1)//проверяем введенные значения
        {
            flagCel = digitT % 10;
            digitT = digitT / 10;
            i = i + 1;
        }
    while (drT >= 1 && flagDr <= 1)
        {
            flagDr = drT % 10;
            drT = drT / 10;
        }
 
    int two = 1;//степень двойки
    int sum = 0;//сумма для целой части
    double sumD = 0;//сумма для дробной части
    digitT = digit;//запись переменных для
    drT = dr;//дальнейшей проверки
    if (flagCel>1 || flagDr>1)
        {
            //Проверка на двоичность
            cout<<"It's not two-position system!\n";
        }
    else
        {
            //Цикл выполняется, если число двоичное
            while (i > 0)//непосредственно перевод значений целой части
                {
                    flagCel = digitT % 10;//проверяем значение крайнего разряда
                    digitT = digitT / 10;//уменьшаем количество разрядов
                    sum = sum + flagCel * two;//возводим в степень
                    two = two * 2;
                    i = i - 1;//отмечаем уменьшение разряда на счетчике
                }
            while (j > 0)
                {
                    flagDr = drT % 10;
                    drT = drT / 10;
                    //почему-то не работает при флаге равном нулю
                    //исключим такую ситуацию
                    if (flagDr != 0)
                    sumD = sumD + 1/(flagDr * pow(2,j));//находим десятичное значение
                    j = j - 1;//понижаем разряд
                }
            //Вывод результатов
            cout<<"Digits: \n"
                    <<"2-p: "<<digit<<endl
                        <<"10-p: "<<sumD+sum;
        }
    getch();//для ожидания нажатия клавиши, что бы консоль не закрывалась
    return(0);
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.12.2012, 11:50     Перевод из двоичной системы счисления в десятичную с плавающей запятой
Посмотрите здесь:

Перевод целого (дробного) числа из двоичной системы счисления в десятичную C++
C++ Написать рекурсивный алгоритм перевода из двоичной системы счисления в десятичную ( из восьмеричной и шестнадцатеричной в десятичную)
C++ Перевод числа из двоичной системы счисления в десятичную
C++ перевод десятичной дроби из двоичной системы счисления в десятичную
Рекурсивный перевод из двоичной системы счисления в десятичную C++
C++ Перевод из двоичной системы счисления в десятичную
C++ Перевод из двоичной системы счисления в десятичную
Перевод из двоичной системы счисления в десятичную C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Kuzia domovenok
 Аватар для Kuzia domovenok
1882 / 1737 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
25.12.2012, 12:04     Перевод из двоичной системы счисления в десятичную с плавающей запятой #2
код не читал. Надеюсь ты реализуешь двоичные дроби, а не десятичные?
Azen
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 4
25.12.2012, 12:06  [ТС]     Перевод из двоичной системы счисления в десятичную с плавающей запятой #3
твои надежды не оправдались. понятия не имею, как реализовывать двоичные дроби
Yandex
Объявления
25.12.2012, 12:06     Перевод из двоичной системы счисления в десятичную с плавающей запятой
Ответ Создать тему
Опции темы

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