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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 29, средняя оценка - 4.72
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
#1

Перевод из 2сс в 10сс - C++

21.06.2011, 19:51. Просмотров 3791. Ответов 25
Метки нет (Все метки)

Помогите пожалуйста написать программу! Перевод дробной части 2го числа в дробное десятичное! Входное 2ое число константа задается как массив символов, выходное 10ое число типа float, т.е. входное 0,101 выходное 0,625. !Не использовать библиотечные функции
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.06.2011, 19:51
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Перевод из 2сс в 10сс (C++):

Программа для перевода чисел из 10сс в 2сс - C++
Всем здорова! Вот тут такая проблема, в код написан правильно, работает, но вот, под строку вывода числа конечного зарезервировано 30...

Перевод с 2сс в любую - C++
Помогите пожалуйста начинающему программисту написать алгоритм перевода двоичного числа в 8,10,16 системы счисления. Если можно с описанием...

Перевод из 10СС - C++
извините за граматику!! как перевести десятичное число у q-систему счисления. например, троичную, пятиричную.q вводить с клавиатуры.и...

перевод из 10сс в 16сс - C++
Всем привет!) Подкиньте пожалуйста прогу перевода из 10сс в 16сс, где функция находит в строке десятичные константы и заменяет их на...

Перевод из 10СС в 2,8,16СС. - C++
Не знаю как написать программу на языке си по переводу любого вводимого целого числа в 10 сс(системе счисления) в любую другую 2,8 или...

не могу дописать функцию перевода текста на 2сс,не могу возвращать переведенный текст - C++
void itoa(char str){ int i; char buf; char url; char yn; int x=0; i=0; while(str){ _itoa_s( (unsigned char)str, buf, 2);...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
kravam
быдлокодер
1694 / 881 / 44
Регистрация: 04.06.2008
Сообщений: 5,441
21.06.2011, 22:38 #2
Это тебе надо просто 101 перевести в десятичную систему будет 5, потом 1000 в двоичную систему, будет 8 (1000 взялось вот откуда: смотрим, сколько цифр в дробной части двоичного числа, столько и нолей после единицы- в данном случае три), результат 5/8

Переводить можно так: четвёртый пост рулит
http://www.cyberforum.ru/cpp-beginne...tml#post154443
grizlik78
Эксперт С++
1908 / 1440 / 111
Регистрация: 29.05.2011
Сообщений: 2,996
22.06.2011, 00:50 #3
На самом деле не очень понятно, нужен перевод из двоичного текстового представления в машинное или в десятичное текстовое.
В принципе в машинное представление float двоичное число можно перевести оперируя исключительно битами, но вот несколько более универсальный вариант. Правда не слишком хорошо читаемый
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
#include <iostream>
 
using namespace std;
 
int main()
{
    string str;
    cout << "Input binary value: " << endl;
    cin >> str;
    float value = 0;
    char ch;
    int i = 0;
    // целая часть
    while ( (ch = str[i++]) == '0' || ch == '1' )
    {
        value *= 2;
        if (ch == '1')
            value += 1;
    }
    if (ch == '.')
    {
        // дробная часть
        float frac = 1.0f;
        while ( (ch = str[i++]) == '0' || ch == '1' )
        {
            frac /= 2;
            if ( ch == '1')
                value += frac;
        }
    }
    cout << endl << str << " -> " << value << endl;
    return 0;
}
Добавлено через 1 час 2 минуты
Блин, забыл проверять границу. Правда заголовки циклов мне всё меньше нравятся. С ASCIIZ-строками было бы компактнее (непосредственно алгоритм перевода), кто там что говорил, при их неэффективность?
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
#include <iostream>
 
using namespace std;
 
int main()
{
    string str;
    cout << "Input binary value: " << endl;
    cin >> str;
    float value = 0;
    size_t i = 0;
    // целая часть
    while ( i < str.length() && (str[i] == '0' || str[i] == '1' ))
    {
        value *= 2;
        if (str[i++] == '1')
            value += 1;
    }
    // дробная часть
    if (i < str.length() && str[i++] == '.')
    {
        float frac = 1.0f;
        while ( i < str.length() && (str[i] == '0' || str[i] == '1' ))
        {
            frac /= 2;
            if ( str[i++] == '1')
                value += frac;
        }
    }
    cout << endl << str << " -> " << value << endl;
    return 0;
}
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 09:59  [ТС] #4
Эмм, я использую Borland C++ 3.1, И можно в место строк использовать массив символов???
grizlik78
Эксперт С++
1908 / 1440 / 111
Регистрация: 29.05.2011
Сообщений: 2,996
22.06.2011, 10:18 #5
Так используйте, кто же не даёт-то?
На самом деле там практически никаких полезных свойств string и не используется, кроме удобства ввода. Главное же было алгоритм показать, неужели он остался непонятным?
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
#include <iostream.h>
#include <iomanip.h>
 
int const BUF_SIZE = 256;
 
int main()
{
    char str[BUF_SIZE];
    cout << "Input binary value: " << endl;
    cin >> setw(BUF_SIZE) >> str;
    float value = 0;
    char *s = str;
    // целая часть
    while (*s == '0' || *s == '1')
    {
        value *= 2;
        if (*s++ == '1')
            value += 1;
    }
    // дробная часть
    if (*s == '.')
    {
        ++s;
        float frac = 1.0f;
        while (*s == '0' || *s == '1')
        {
            frac /= 2;
            if ( *s++ == '1')
                value += frac;
        }
    }
    *s = '\0'; // а уберём-ка ещё и мусор на хвосте
    cout << endl << str << " -> " << value << endl;
    return 0;
}
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 13:40  [ТС] #6
А если вводная строка, константа, как ее задать в начале???
grizlik78
Эксперт С++
1908 / 1440 / 111
Регистрация: 29.05.2011
Сообщений: 2,996
22.06.2011, 13:53 #7
C++
1
char str[] = "0.1011101";
Если совсем-совсем константа, то
C++
1
char const *str = "0.1011101";
но тогда из кода надо убрать *s = '\0';
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 14:05  [ТС] #8
Ясно, теперь более мене понятно, а как реализовать перевод из вещественного (результат) в строковое 2ое??? т.е. все наоборот... перевести из 2 в 10 я смогу (умножая дробь на 2 и выделяя целое от умножения) а вот в строку переделать это вряд ли...
grizlik78
Эксперт С++
1908 / 1440 / 111
Регистрация: 29.05.2011
Сообщений: 2,996
22.06.2011, 15:25 #9
Цитата Сообщение от auqarisu Посмотреть сообщение
перевести из 2 в 10 я смогу (умножая дробь на 2 и выделяя целое от умножения) а вот в строку переделать это вряд ли...
Умножая дробь на 2 и выделяя целое получится перевод не из двоичного в десятичное, а перевод из машинного представления в последовательность единиц и нулей. Вот в зависимости от очередного результата и надо записывать в очередную позицию строки либо символ '0', либо символ '1'.
C
1
2
3
4
5
6
int result;
// ... тут выделение целой части в переменную result ...
if (result == 0)
  str[i++] = '0';
else
  str[i++] = '1';
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 16:00  [ТС] #10
Как выделить целую часть приумножении на 2? И как потом взять дробную??? (допустим имеем val типа float (=0.625) умножаем на 2 получаем 1,250 и допустим res типа float, res="%1.0f"val)???
grizlik78
Эксперт С++
1908 / 1440 / 111
Регистрация: 29.05.2011
Сообщений: 2,996
22.06.2011, 16:02 #11
C
1
int result = 2*0.625;
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 17:11  [ТС] #12
Где тут недочет??? Программа выдает набор символов...
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
#include <iostream.h>
#include <iomanip.h>
 
int const BUF_SIZE = 5;
char *mas[3]={"0.100","0.110","0.111"};
 
float Ch2fl(char *str)
{
    float value = 0;
    char *s = str;
    while (*s == '0' || *s == '1')
    {
    value *= 2;
    if (*s++ == '1')
        value += 1;
    }
    if (*s == '.')
    {
    ++s;
    float frac = 1.0f;
    while (*s == '0' || *s == '1')
    {
        frac /= 2;
        if ( *s++ == '1')
        value += frac;
    }
    }
    *s = '\0'; // а уберём-ка ещё и мусор на хвосте
    return value;
}
 
char Fl2ch (float val)
{
 char res[5];
 char res1[5];
 res1[0]='0';
 res1[1]='.';
 int j,i,b;
 for(i=0;i<3;i++)
 {
   int b=2*val;
   if (b==1)
   {
   res1[i+2]='1';
   val=(2*val)-1;
   }
   else res1[i+2]='0';
 }
 for(j=0;j<5;j++)
  res[j]=res1[j];
 
 return res[5];
}
 
int main()
{
 int i;
 float tmp;
 char *tmp2;
 for(i=0; i<3; i++)
 {
  tmp=Ch2fl(mas[i]);
  cout<<setw(10)<<tmp;
  *tmp2=Fl2ch(tmp);
  cout<<setw(10)<<tmp2<<'\n';
 }
 return 0;
}
Добавлено через 3 минуты
первая функция нормально работает, а вот 2ая нет
grizlik78
Эксперт С++
1908 / 1440 / 111
Регистрация: 29.05.2011
Сообщений: 2,996
22.06.2011, 17:13 #13
Если целая часть равна 1, то число val изменяется (и вроде правильно), а если 0, то не меняется. А должно умножаться на 2.
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 17:16  [ТС] #14
Да, точно. Но все равно программа вместо 2ого кода выдает разные символы ромбики, и т.д. и т.п.
grizlik78
Эксперт С++
1908 / 1440 / 111
Регистрация: 29.05.2011
Сообщений: 2,996
22.06.2011, 17:17 #15
Ну и вызов функции неправильный. И она должна возвращать указатель на строку, а не символ. И буфер под строку где-то во вне должен создаваться.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.06.2011, 17:17
Привет! Вот еще темы с ответами:

Нужно найти ошибку. Перевод из 10СС в 2СС - C#
Помогите найти ошибку. Перевод из 10СС в 2СС Вот два кода: Помогите исправить одну программу.Спасибо //выводит числа правильно, но...

Перевод числа из 10сс в 2сс,8сс и 16сс с заданием числа вещественного типа - Pascal
Здраствуйте. Помогите с решением задачи. Задание: перевести число из десятичной системы счисления в двоичную, восьмиричную и...

Как число из 10сс перевести в 2сс? - C (СИ)
Получаю в программе на си в переменной int 4х байтовое число в 10сс 24576 мне из него нужно получить 2 младших байта в 2сс (2 старших байта...

перевести число из 10СС в 2СС и составить блок схему - Pascal
здравствуйте! помогите пожалуйста составить программу для перевода чисел из десятичной системы счисления в двоичную и составить по ней блок...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
22.06.2011, 17:17
Ответ Создать тему
Опции темы

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