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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Задача на поиск числа среди введеных http://www.cyberforum.ru/cpp-beginners/thread745187.html
Вводим числа k,l,m - среди этих чисел вводятся два одинаковых, а третье является отличным от них. Необходимо переменной n присвоить значение числа которое отличается от двух одинаковых. Помогите пожалуйста с решением, а то в c++ новичек, не очень хорошо получается понимать язык
C++ Инициализация переменной в struct Как исправить эту ошибку? error C2864: wmain::Triangle::name: в пределах класса могут быть инициализированы только статические константные данные-члены целого типа struct Triangle { int a; int b; int c; const char name = "Треугольник"; }; http://www.cyberforum.ru/cpp-beginners/thread745175.html
Перевод с арабской на римскую сс и наоборот C++
Программа работает на половину, переводит только с римских чисел на арабские, помогите доделать что бы переводила и с арабских на римские #include <string.h> #include <stdio.h> #include <stdlib.h> #include <conio.h> #include <iostream> using namespace std;
C++ Определить, есть ли в последовательности хотя бы одна пара одинаковых "соседных" чисел
дано последовательность натуральных чисел а1,а2..а10. Определить есть ли в последовательности хотя бы одна пара одинаковых "соседных" чисел.
C++ Немогу понять где ошибки http://www.cyberforum.ru/cpp-beginners/thread745148.html
#include<iostream.h> #include<conio.h> const int n=5; void In(float x); void Minimum(float x, float&); void Maximum(float x, float&, float&, float&); //void zamena (float&, float&); void Out(float x, float&, float&); void main() {
C++ На циклы:Найти на отрезке [n,m] натураьное число Найти на отрезке натуральное число, имеющее наибольшее кол-во делителей. подробнее

Показать сообщение отдельно
Azen
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 4

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

25.12.2012, 11:50. Просмотров 1224. Ответов 2
Метки (Все метки)

Помогите найти ошибки в коде. Выводит не верный результат при введенных данных (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);
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru