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

Композиция двух классов и вложенные классы - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Нахождение максимальной длины слова http://www.cyberforum.ru/cpp-beginners/thread227316.html
Помогите исправить программу задание: Составить программу, которая в заданном тексте находит слово (слова) максимальной длины. В файле результатов должен быть исходный текст, значение максимальной...
C++ Все элементы вектора меньше модуля минимального элемента заменить на ноль, остальные сложить всем привет. народ проверьте мой исходный код и поправьте если че не так а то я накосячил а он не выполняется условие дан вектор. все элементы меньше модуля минимального элемента заменить на 0,... http://www.cyberforum.ru/cpp-beginners/thread227315.html
Строки в C++ C++
Вот такая задача: Написать программу которая считывает текст из файла и выводит на экран только строки, содержащие двузначные числа. Есть задача сделанная с немного другим условием, строки...
Двусвязный список C++
Привет, народ. Помогите плиз найти ошибку. #include "iostream" #include "cmath" using namespace std; struct elem { int data; elem *next;
C++ Цикл for http://www.cyberforum.ru/cpp-beginners/thread227258.html
Есть формула n*(n+1) нужно настроить цикл так что бы результат получался как при просчете этой формулы. for (i=2; i<=2*n; i+=2) { progrest = 0; progrest+=i; progres = progrest+(n*2);...
C++ Обратная матрица Срочно в СИ нужна программа нахождения обратной матрицы. Что-то я пробовала методом Гаусса у меня на первой же функции ошибка, расскажите какие еще есть альтернативные способы? подробнее

Показать сообщение отдельно
2009
2 / 2 / 0
Регистрация: 23.11.2009
Сообщений: 35

Композиция двух классов и вложенные классы - C++

12.01.2011, 00:23. Просмотров 5093. Ответов 7
Метки (Все метки)

Привет, народ! Собственно говоря вот задача.
Существуют 2 класса:
1. Создать класс LongLong для работы с целыми числами из 64 бит. Число должно быть представлено двумя полями: long — старшая часть, unsigned long — младшая часть. Должны быть реализованы арифметические операции, присутствующие в С++ (без присваивания), и сравнения.

2. Создать класс Fraction для работы с дробными числами. Число должно представлено двумя полями: целая часть — длинное целое со знаком, дробная часть — беззнаковое короткое целое. Реализовать арифметические операции сложения, вычитания, умножения и операции сравнения.

Необходимо сделать 1)их композицию и 2)вложить их друг в друга.
Можно сказать ,что на 50 % у меня уже сделано.
Конечно вряд ли кто-нибудь захочет делать это, но я надеюсь что все-таки кто-то откликнется и найдется программист, для которого эта задача окажется пустяковой и он сделает её)))
Заранее спасибо!
------------------------------Композиция---------------------------------
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
#include<iostream>
#include<string>
#include<sstream>
#include<cmath>
#pragma pack(1)
using namespace std;
 
//--класс Longlong--
class Longlong
{ 
  long st_part;
  unsigned long ml_part;
  public:
    bool init(long st,unsigned long ml)
    {
       st_part=st;
       ml_part=ml;
            return true;
    }
 
  public:
 
    Longlong(long st_part=0,unsigned long ml_part=0);   //конструктор
    friend istream &operator>>(istream &t,Longlong &A); //функция ввода
    friend ostream &operator<<(ostream &t,Longlong A);  //функция вывода
    friend Longlong operator+(Longlong B,Longlong A);   //функция сложения
    friend Longlong operator-(Longlong A,Longlong C);   //функция вычитания
    string operator!();                             //функция в строку
    friend double operator*(Longlong A,double a);   //функция умножения
    double operator/(Longlong B);                  //функция деления
 
    
};
//--конструктор--
Longlong::Longlong(long st_part, unsigned long ml_part)
{
    if(!init(st_part, ml_part))throw "Функции не понравились ваши данные!";
}
//--функция ввода--
 istream &operator>>(istream &t,Longlong &A)
 { long st_part;
   unsigned long ml_part;  
   do{
cout<<endl;
cout<<"Задавать только корректные данные"<<endl;
cout<<"Введите старшую часть: ";cin>>st_part;cout<<endl;
cout<<"Введите младшую часть: ";cin>>ml_part;cout<<endl;
  }while(!A.init(st_part, ml_part));
  A.st_part=st_part;
  A.ml_part=ml_part;
return t;
 }
//--функция вывода--
ostream &operator<<(ostream &t,Longlong A)
{
    t<<"Старшая часть: "<< A.st_part <<"; Младшая часть: "<<A.ml_part<<endl;
return t;
}
//--перевод в строку--
string Longlong::operator !()
{ostringstream os;
 Os<<"Старшая часть: "<<st_part<<"; Младшая часть: "<<ml_part<<endl;
return os.str();
}
//--функция сложения--
Longlong operator+(Longlong B,Longlong A)
{ Longlong D;
  D.st_part=(4294967295-B.ml_part<A.ml_part)? 1:0;
  D.ml_part=A.ml_part+B.ml_part;
  D.st_part+=(A.st_part+B.st_part);
  return D; }
//--функция вычитания--
Longlong operator-(Longlong A,Longlong C)
{ LongLong D;
  D.st_part=(B.ml_part<A.ml_part)? -1:0;
  D.ml_part=B.ml_part-A.ml_part;
  D.st_part+=(B.st_part-A.st_part);
return D; }
//--функция умножения--
double operator*(Longlong A,double B)
{ LongLong D;
  unsigned int limit=4294967295;
  if(D.ml_part!=0)
    D.st_part=(limit/B.ml_part<A.ml_part)? A.ml_part/(limit/B.ml_part):0;
    else D.st_part=0;
    D.ml_part=A.ml_part*B.ml_part;
    D.st_part+=(A.st_part*B.st_part);
    return D;
}
//--функция деления --
 double Longlong:: operator /(Longlong B) 
{     LongLong D;
    if(A.ml_part!=0&&A.st_part!=0)
    {
        D.ml_part=B.ml_part/A.ml_part;
        D.st_part=B.st_part/A.st_part;
    }
return D;}
 
 
///// Вот здесь то я и не знаю(((
class  Fraction
{ 
}




--------------------------------Вложенный класс-------------------------------
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
#include<iostream>
#include<string>
#include<sstream>
#include<cmath>
#pragma pack(1)
using namespace std;
//---Класс Fraction---
class  Fraction
{public:
//--Класс Longlong--
    class Longlong
{ 
  long st_part;
  unsigned long ml_part;
  public:
    bool init(long st,unsigned long ml)
    {
       st_part=st;
       ml_part=ml;
            return true;
    }
 
  public:
 
    Longlong(long st_part=0,unsigned long ml_part=0);   //конструктор
    friend istream &operator>>(istream &t,Longlong &A); //функция ввода
    friend ostream &operator<<(ostream &t,Longlong A);  //функция вывода
    friend Longlong operator+(Longlong B,Longlong A);   //функция сложения
    friend Longlong operator-(Longlong A,Longlong C);   //функция вычитания
    string operator!();                             //функция в строку
    friend double operator*(Longlong A,double a);   //функция умножения
    double operator/(Longlong B);                  //функция деления
      ~Longlong(); //деструктор
};
 
private:
//////////Из-за незнания создания класса Fraction не могу дописать
{
 
 
 
}
//--функция ввода--
 istream &operator>>(istream &t,Longlong &A)
 { long st_part;
   unsigned long ml_part;  
   do{
cout<<endl;
cout<<"Задавать только корректные данные"<<endl;
cout<<"Введите старшую часть: ";cin>>st_part;cout<<endl;
cout<<"Введите младшую часть: ";cin>>ml_part;cout<<endl;
  }while(!A.init(st_part, ml_part));
  A.st_part=st_part;
  A.ml_part=ml_part;
return t;
 }
//--функция вывода--
ostream &operator<<(ostream &t,Longlong A)
{
    t<<"Старшая часть: "<< A.st_part <<"; Младшая часть: "<<A.ml_part<<endl;
return t;
}
//--перевод в строку--
string Longlong::operator !()
{ostringstream os;
 Os<<"Старшая часть: "<<st_part<<"; Младшая часть: "<<ml_part<<endl;
return os.str();
}
//--функция сложения--
Longlong operator+(Longlong B,Longlong A)
{ Longlong D;
  D.st_part=(4294967295-B.ml_part<A.ml_part)? 1:0;
  D.ml_part=A.ml_part+B.ml_part;
  D.st_part+=(A.st_part+B.st_part);
  return D; }
//--функция вычитания--
Longlong operator-(Longlong A,Longlong C)
{ LongLong D;
  D.st_part=(B.ml_part<A.ml_part)? -1:0;
  D.ml_part=B.ml_part-A.ml_part;
  D.st_part+=(B.st_part-A.st_part);
return D; }
//--функция умножения--
double operator*(Longlong A,double B)
{ LongLong D;
  unsigned int limit=4294967295;
  if(D.ml_part!=0)
    D.st_part=(limit/B.ml_part<A.ml_part)? A.ml_part/(limit/B.ml_part):0;
    else D.st_part=0;
    D.ml_part=A.ml_part*B.ml_part;
    D.st_part+=(A.st_part*B.st_part);
    return D;
}
//--функция деления --
 double Longlong:: operator /(Longlong B) 
{     LongLong D;
    if(A.ml_part!=0&&A.st_part!=0)
    {
        D.ml_part=B.ml_part/A.ml_part;
        D.st_part=B.st_part/A.st_part;
    }
return D;}
 
 
//////Здесь аналогично
Добавлено через 4 часа 45 минут
Чтобы тема не забывалась..
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru