С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/15: Рейтинг темы: голосов - 15, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 4
1

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

25.12.2012, 11:50. Показов 2950. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите найти ошибки в коде. Выводит не верный результат при введенных данных (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);
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
Блог
25.12.2012, 11:50
Ответы с готовыми решениями:

Перевод из двоичной системы счисления в десятичную
Я создал программу, но вот она выдает размерность введенного массива, вместо десятичного числа....

Перевод из двоичной системы счисления в десятичную
Помогите пожалуйста перевести число из 2-ой сс в 10 сс. Буду очень благодарен:)

Перевод из двоичной системы счисления в десятичную
как создать код который переводит с двоичной системы в десятичную без использования DEC и прочего?

Перевод из двоичной системы счисления в десятичную
#include &lt;iostream&gt; #include &lt;cmath&gt; #include &lt;cstring&gt; #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt;...

2
4264 / 3323 / 925
Регистрация: 25.03.2012
Сообщений: 12,520
Записей в блоге: 1
25.12.2012, 12:04 2
код не читал. Надеюсь ты реализуешь двоичные дроби, а не десятичные?
0
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 4
25.12.2012, 12:06  [ТС] 3
твои надежды не оправдались. понятия не имею, как реализовывать двоичные дроби
0
25.12.2012, 12:06
cpp_developer
Эксперт
20123 / 5690 / 417
Регистрация: 09.04.2010
Сообщений: 12,546
Блог
25.12.2012, 12:06
Помогаю со студенческими работами здесь

Перевод из двоичной системы счисления в десятичную
Программа не работает для отрицательных чисел. Помогите найти ошибку. #include &quot;stdafx.h&quot;...

Рекурсивный перевод из двоичной системы счисления в десятичную
Вот мой код: #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;math.h&gt; using namespace std;...

Перевод числа из двоичной системы счисления в десятичную
написать программу, которая переводит число из двоичной системы счисления в десятичную

Перевод десятичной дроби из двоичной системы счисления в десятичную
Подскажите пожалуйста, не смог найти на форуме код, который бы осуществлял перевод десятичной дроби...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru