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

Математические операции для дробного числа ( заданного структурой ) - C++

Восстановить пароль Регистрация
 
Hunter13ua
46 / 46 / 5
Регистрация: 25.10.2011
Сообщений: 183
14.10.2013, 10:04     Математические операции для дробного числа ( заданного структурой ) #1
Структура:
C++
1
2
3
4
5
struct TFraction {
        long ing; // целая часть
        unsigned short frc; //дробная часть
        unsigned short count; //кол-во нулей в дробной части
};
Тобишь число "145.00123" запишет как
C++
1
2
3
object.ing = +145;
object.frc = 123;
object.count = 2;
Нужны операции суммирования, вычитания, умножения на число и операцию сравнения. Очень нужно! Буду очень благодарен!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.10.2013, 10:04     Математические операции для дробного числа ( заданного структурой )
Посмотрите здесь:

C++ [C++] Возведение дробного числа в дробную степень
C++ Произвести математические операции над матрицами
Вывод ошибки для дробного и отрицательного числа C++
C++ Функции. побитовые операции. Написать функцию, которая для заданного целого числа Х вычисляет количество единичных битов в этом числе
Возведение дробного числа в степень C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ninja2
 Аватар для ninja2
230 / 186 / 7
Регистрация: 26.09.2012
Сообщений: 2,018
Завершенные тесты: 1
14.10.2013, 10:40     Математические операции для дробного числа ( заданного структурой ) #2
От пытался сделать, но почемуто когда я передаю в конструктор число типа double оно у меня меняется на левое число
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
using namespace::std;
struct TFraction {
    long ing; // целая часть
    unsigned short frc; //дробная часть
    unsigned short count; //кол-во нулей в дробной части
    
TFraction(double d)
    {
        //stringstream ss;
        cout <<setprecision(20)<<fixed<<"d= "<<d<<endl;
    }
 
};
 
int main()
{
    TFraction T(145.00123);//
 
    return 0;
}
В сам конструктор приходит число не 145.00123, а 145.00122999999999999999 Почему так? Куда делась одна стотысячная????
SatanaXIII
Супер-модератор
Эксперт С++
 Аватар для SatanaXIII
5547 / 2561 / 233
Регистрация: 01.11.2011
Сообщений: 6,330
Завершенные тесты: 1
14.10.2013, 10:49     Математические операции для дробного числа ( заданного структурой ) #3
Цитата Сообщение от ninja2 Посмотреть сообщение
Почему так? Куда делась одна стотысячная?
Добро пожаловать в мир плавающей точки.
ninja2
 Аватар для ninja2
230 / 186 / 7
Регистрация: 26.09.2012
Сообщений: 2,018
Завершенные тесты: 1
14.10.2013, 11:38     Математические операции для дробного числа ( заданного структурой ) #4
Hunter13ua, Можно как то так сделать (гомнокодец):
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#include <iostream>
#include <sstream>
#include <regex>
#include <string>
#include <cstdlib>
#include <iomanip>
using namespace::std;
 
struct TFraction {
    long ing; // целая часть
    unsigned short frc; //дробная часть
    unsigned short count; //кол-во нулей в дробной части
    
    TFraction(double d)
    {
        stringstream ss;
        ss <<setprecision(7)<<fixed<<d;
        string s;
        ss >>s;
        if(s.find('.')!=string::npos)
        {
            smatch sm;
            if(regex_search(s,sm,regex("(\\d+)\\.(0*)(\\d+)$")))
            {
                ss.clear(); ss<<sm[1].str(); ss>>ing;
                count=sm[2].str().size();
                ss.clear(); ss<<sm[3].str(); ss>>frc;
            }
        }
        else
        {
            ing=d;
            frc=0;
            count=0;
        }
    }
 
    TFraction(const TFraction& t)
        :ing(t.ing),
        frc(t.frc),
        count(t.count)
    {}
    
    TFraction& operator=(const TFraction& t)
    {
        ing=t.ing;
        frc=t.frc;
        count=t.count;
        return *this;
    }
 
    operator double()
    {
        double res;
        stringstream ss;
        string s,s1;
        ss <<ing; ss>>s1; ss.clear();
        s+=s1; s+=".";
        ss <<frc; ss>>s1; ss.clear();
        for(int i=0;i<count;i++)
            s+='0';
        s+=s1;
        ss <<s;
        ss>>res;
        return res;
    }
 
    TFraction& operator*(int n)
    {
        double d=*this;
        d=d*n;
        *this=TFraction(d);
        return *this;
    }
 
};
 
TFraction operator+(TFraction a, TFraction b)
{
    double a1=a;
    double b1=b;
    double res=a1+b1;
    return TFraction(res);
}
 
TFraction operator-(TFraction a, TFraction b)
{
    double a1=a;
    double b1=b;
    double res=a1-b1;
    return TFraction(res);
}
 
bool operator==(const TFraction a, const TFraction b)
{
    return a.ing==b.ing&&a.frc==b.frc&&a.count==b.count;
}
 
bool operator!=(const TFraction a, const TFraction b)
{
    return !(a==b);
}
 
 
int main()
{
    TFraction T1(145.00123);
    TFraction T2(145.00124);
    TFraction T3(T1);
    T3=T1+T2;
    double t;
    t=T3;
    cout <<setprecision(7)<<fixed<<t<<endl;
    T3=T3*2;
    t=T3;
    cout <<setprecision(7)<<fixed<<t<<endl;
    
 
    return 0;
}
Algoritmer
 Аватар для Algoritmer
155 / 95 / 13
Регистрация: 07.03.2013
Сообщений: 477
Записей в блоге: 1
14.10.2013, 13:10     Математические операции для дробного числа ( заданного структурой ) #5
Цитата Сообщение от ninja2 Посмотреть сообщение
В сам конструктор приходит число не 145.00123, а 145.00122999999999999999 Почему так? Куда делась одна стотысячная????
Передавать в конструктор нужно либо строку, либо 2 параметра: 1-й double, 2-й кол-во цифр после запятой

Добавлено через 4 минуты
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
struct TFraction {
    long ing; // целая часть
    unsigned short frc; //дробная часть
    unsigned short count; //кол-во нулей в дробной части
    
TFraction(char *str)
    {
        int len=strlen(str);
        bool isIng=true;
        for(int i=0;i<len;i++)
        {
                if(isdigit(str[i]))
                {
                            if(isIng)
                             
{
ing*=10; ing+=(str[i]-48);
}
else ...по аналогии
                 }
                  else if(str[i]=='.') isIng=false;
 
        }     
    }
 
};
ninja2
 Аватар для ninja2
230 / 186 / 7
Регистрация: 26.09.2012
Сообщений: 2,018
Завершенные тесты: 1
14.10.2013, 14:37     Математические операции для дробного числа ( заданного структурой ) #6
Цитата Сообщение от Algoritmer Посмотреть сообщение
Передавать в конструктор нужно либо строку, либо 2 параметра: 1-й double, 2-й кол-во цифр после запятой
Можно и не передавать, больше 7 все рамно не запишем ( unsigned short frc; //дробная часть)
Hunter13ua
46 / 46 / 5
Регистрация: 25.10.2011
Сообщений: 183
14.10.2013, 14:55  [ТС]     Математические операции для дробного числа ( заданного структурой ) #7
ninja2, я, кажется, чего-то не знаю про преобразование типов О.о
C++
1
2
3
4
5
6
7
TFraction operator+(TFraction a, TFraction b)
{
    double a1=a;
    double b1=b;
    double res=a1+b1;
    return TFraction(res);
}
Как оно работает? о.О
---------------------------------------------------------------------------------
А, оу.. я слепой. Не сразу заметил переопределённую double(). Спасибо большое! От меня еще 100% будут вопросы, т.к. почти со всеми подключенными библиотеками не работал.
ninja2
 Аватар для ninja2
230 / 186 / 7
Регистрация: 26.09.2012
Сообщений: 2,018
Завершенные тесты: 1
14.10.2013, 14:58     Математические операции для дробного числа ( заданного структурой ) #8
Hunter13ua, в классе я определил оператор operator double() в класе TFraction от он переводит в double смотри его код.
Можно было просто создать поле double p в самой структуре и хранить исходное значение что бы не преобразовывать. Это так как пример. Вся эта задача просто закрепить навыки работы с классами. Там код так сказать гамнокодец, в реале все проще б делалось.
Algoritmer
 Аватар для Algoritmer
155 / 95 / 13
Регистрация: 07.03.2013
Сообщений: 477
Записей в блоге: 1
14.10.2013, 15:05     Математические операции для дробного числа ( заданного структурой ) #9
Цитата Сообщение от ninja2 Посмотреть сообщение
Можно и не передавать, больше 7 все рамно не запишем
7 значащих это да. А как на счет количества нулей?
ninja2
 Аватар для ninja2
230 / 186 / 7
Регистрация: 26.09.2012
Сообщений: 2,018
Завершенные тесты: 1
14.10.2013, 15:10     Математические операции для дробного числа ( заданного структурой ) #10
Цитата Сообщение от Algoritmer Посмотреть сообщение
7 значащих это да. А как на счет количества нулей?
А что нули? Да пофигу на них.

Вообще не 7 значащих, а любые 7 цифр после точки, там же стоит fixed. после точки 7, больше мне не нужно.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.10.2013, 20:36     Математические операции для дробного числа ( заданного структурой )
Еще ссылки по теме:

C++ Комплексные числа. Реализовать класс и математические операции
C++ Дана строка. Определить, представляет ли она собой запись целого числа или запись дробного числа
C++ Возведение дробного числа в большую степень

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

Или воспользуйтесь поиском по форуму:
Hunter13ua
46 / 46 / 5
Регистрация: 25.10.2011
Сообщений: 183
16.10.2013, 20:36  [ТС]     Математические операции для дробного числа ( заданного структурой ) #11
Спасибо еще раз, но мне не поможет. Почему? Потому, что запрещено использовать stl. Да и вообще сторонние библиотеки. Можно iostream, и стандартные. Задание давали и принимают депилы.
Так что тема актуальна. Ввод, инициализация, вывод на экран есть. Переводит со строки в структуру и обратно. Нужны операции плюс и минус

Добавлено через 30 минут
Рабочий код(если пригодится, и если таки кто-нибудь еще поможет).
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#include <iostream>
using namespace std;
 
struct TFraction {
        long ing;
        unsigned short frc;
        unsigned short count;
};
 
class cFraction {
    private:
        TFraction object;
    public:
        void init(char* num_str);
        void input(void);
        void output(void);
        char* toPChar(void);
        TFraction getStruct(void);
        cFraction cFraction::operator+(cFraction &b); //нужен
};
 
int Length(const TFraction &tfr);
int Length(int N);
 
int _tmain(int argc, _TCHAR* argv[])
{
    cFraction a; a.init("123.0045");
        cout << "A: "; a.output(); cout << endl;
 
        cout << "Input B: ";
    cFraction b; b.input();
        cout << "B: " << b.toPChar() << endl;
        
    cFraction c = a+b;
    system("pause");
    return 0;
}
 
//инициализация объекта
void cFraction::init(char* numstr)
{
        char *dott;
 
        this->object.ing = atol(numstr);
        dott = strstr(numstr,".");
 
        this->object.count = 0;
        if (*dott == '.'){
            while (*(++dott) == '0')
                this->object.count++;
            this->object.frc = (unsigned)atol(dott);
        } else this->object.frc = 0;
}
//ввод данных в объект
void cFraction::input(void)
{
        char numstr[30];
        cin >> numstr;
        this->init(numstr);
}
//вывод данных на экран
void cFraction::output(void)
{
        cout << this->object.ing << ".";
        for(int i=0; i<this->object.count; i++)
            cout << "0";
        cout << this->object.frc;
}
//возвращение строки с данными
char* cFraction::toPChar(void)
{
        char *num_str = new char [30];
        for(int i=0; i<30; i++)
            num_str[i]=0;
        _itoa_s(this->object.ing,num_str,15,10);
 
        unsigned dott_pos = 0;
        while ( num_str[dott_pos] != '\0')
                dott_pos++;
        num_str[dott_pos] = '.';
        int temp_pos = dott_pos+1; 
        for( int i=temp_pos; i<this->object.count+temp_pos; i++) {
            dott_pos++;
            num_str[i] = '0';
        }
        _itoa_s(this->object.frc, &num_str[dott_pos+1],15,10);
        return num_str;
}
//возвращение структуры
TFraction cFraction::getStruct(void)
{
    return this->object;
}
 
//вспомогательные
int Length(const TFraction &tfr)
{
        char str[20];
        _itoa_s(tfr.frc,&str[0],15,10);
        return strlen(str)+tfr.count;
}
int Length(const int N)
{
        char str[30];
        _itoa_s(abs(N),&str[0],15,10);
        return strlen(str);
}
Добавлено через 5 часов 48 минут
Код написан. Тема закрыта.
Yandex
Объявления
16.10.2013, 20:36     Математические операции для дробного числа ( заданного структурой )
Ответ Создать тему
Опции темы

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