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

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

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 29, средняя оценка - 4.72
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
21.06.2011, 19:51     Перевод из 2сс в 10сс #1
Помогите пожалуйста написать программу! Перевод дробной части 2го числа в дробное десятичное! Входное 2ое число константа задается как массив символов, выходное 10ое число типа float, т.е. входное 0,101 выходное 0,625. !Не использовать библиотечные функции
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
grizlik78
Эксперт С++
 Аватар для grizlik78
1884 / 1416 / 102
Регистрация: 29.05.2011
Сообщений: 2,961
22.06.2011, 19:27     Перевод из 2сс в 10сс #21
В принципе да.
Из целого одноразрядного числа символ соответствующей цифры можно получить прибавляя к числу символ '0'.
То есть 5 + '0' == '5'
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 19:40  [ТС]     Перевод из 2сс в 10сс #22
можно использовать 2 массива 1 с типом int 2ой с char оба от 0 до 9 и сравнивая рез-тат записать в массиве результата

Добавлено через 4 минуты
А для обработки float числа использовать цикл while с условием пока есть дробная часть

Добавлено через 1 минуту
только как реализовать это условие??

Добавлено через 2 минуты
что-то типа
C++
1
2
3
4
5
6
7
i=2;
while(a"%1f"<>0)
{
b=a*10;
mas[i]=b+'0';
i++;
}
как то такто???
grizlik78
Эксперт С++
 Аватар для grizlik78
1884 / 1416 / 102
Регистрация: 29.05.2011
Сообщений: 2,961
22.06.2011, 19:59     Перевод из 2сс в 10сс #23
Условие в заголовке цикла какое-то странное. А так похоже.

Добавлено через 1 минуту
C
1
while (a != 0)
правда компилятор может выдавать предупреждение.

Добавлено через 45 секунд
и в самом цикле a надо изменять, иначе цикл не закончится.
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 22:30  [ТС]     Перевод из 2сс в 10сс #24
да, забыл на писать
C++
1
2
3
4
5
6
7
8
i=2;
while(a != 0)
{
int b=a*10;
mas[i]=b+'0';
a=a*10-b;
i++;
}
Добавлено через 5 минут
И как это мутировать с той программой???

Добавлено через 2 часа 16 минут
Эмм, я вот пытался переделать программу для 10 дроби 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
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
#include <iostream.h>
#include <iomanip.h>
 
int const BUF_SIZE = 16;
float const mas[3]={0.123,0.321,0.132};
 
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;
     }
    }
    return value;
}
 
char *Fl2ch (float val, char *str)
{
 str[0]='0';
 str[1]='.';
 int i;
 for(i=0;i<8;i++)
 {
   int b=2*val;
   if (b==1)
   {
   str[i+2]='1';
   val=(2*val)-1;
   }
   else
   {
   str[i+2]='0';
   val *= 2;
   }
 }
 str[i+2]='\0';
 
 return str;
}
 
int main()
{
 int i;
 float tmp;
 char buf[16];
 cout<<setw(10)<<"Start"<<setw(10)<<"1step"<<setw(8)<<"End"<<'\n';
 for(i=0; i<3; i++)
 {
  tmp=mas[i];
  cout<<setw(16)<<mas[i];
  cout<<setw(16)<<Fl2ch(tmp, buf);
  cout<<setw(16)<<Ch2fl(Fl2ch(tmp, buf))<<'\n';
 }
 return 0;
}
Добавлено через 47 секунд
скорее всего проблема дибо в функции маин либо во 2 функции
grizlik78
Эксперт С++
 Аватар для grizlik78
1884 / 1416 / 102
Регистрация: 29.05.2011
Сообщений: 2,961
22.06.2011, 22:41     Перевод из 2сс в 10сс #25
Ну во-первых, в строке 7 не указан тип возвращаемого значения. Это ошибка, там надо указать float.
Ну а во-вторых, большинство конечных десятичных дробей в двоичной форме представляются бесконечной последовательностью. Поэтому расхождения "туда-сюда" будут тем меньше, чем больше битов будет учтено. Ну а с учётом того, что тип float способен хранить только 24 бита мантиссы, то именно столько разрядов начиная с первой единицы должно быть достаточно для устранения ошибки.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.06.2011, 22:46     Перевод из 2сс в 10сс
Еще ссылки по теме:

Программа для перевода чисел из 10сс в 2сс C++
перевод из С++ в Си C++
C++ Перевод C#->C++

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

Или воспользуйтесь поиском по форуму:
auqarisu
5 / 5 / 0
Регистрация: 11.04.2011
Сообщений: 77
22.06.2011, 22:46  [ТС]     Перевод из 2сс в 10сс #26
Ой и в правду, спс вам большое за все!
Yandex
Объявления
22.06.2011, 22:46     Перевод из 2сс в 10сс
Ответ Создать тему
Опции темы

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