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

Класс Hugeint (целые числа) Операции: - =, сравнение(<, >) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Вычислить ряд http://www.cyberforum.ru/cpp-beginners/thread255926.html
Вычислить ряд s=1!/2+2!/(3+4)+3!/(4+5+6)+4!/(5+6+7+8)+5!/(6+7+8+9+10) и т.д. Количество слагаемых зависит от введенного N. Помогите пожалуйста написать на С. Заранее благодарна.....
C++ кто знает как решить...поиогите...в долгу не останусь... Составить описание класса для работы с цепными списками строк (строки произвольной длины) с операциями включения в список, удаление из списка элемента с заданным значением, удаление всего списка или конца списка, начиная с заданного элемента. http://www.cyberforum.ru/cpp-beginners/thread255920.html
Не могу дописать пару операторов в конце программы... C++
#include <iostream> #include <math.h> using namespace std; int main() { system ("cls"); setlocale(LC_ALL,"Rus"); double a, b, c, p, s; cout<< "Программа считает площадь треугольника по формуле Герона."<< endl<<endl;
C++ Использование функций в программе
Подскажите пожалуйста как написать программу Написать функцию вычисления площади треугольника по введённым сторонам
C++ Работа с файлами http://www.cyberforum.ru/cpp-beginners/thread255898.html
Помогите пожалуйста разобраться в задаче....... Заполнить файл последовательного доступа f целыми числами, полученными с помощью генератора случайных чисел. Получить в файле g все компоненты файла f, которые делятся на m и не делятся на n. я смогла найти чтото похожее....записать в файл out.txt последовательного доступа N действительных чисел, введенных с клавиатуры. Подсчитать среднее...
C++ Сортировка списка Люди помогите плиз я уже не могу!! надо сортировать список!!! Останьные недоработки тоже можете указать. Вот код Жду ответов) // WTF_lab_7.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h" #include <stdio.h> подробнее

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

Класс Hugeint (целые числа) Операции: - =, сравнение(<, >) - C++

12.03.2011, 14:26. Просмотров 1375. Ответов 4
Метки (Все метки)

Описать класс, который реализовывает указанный ниже тип данных. Класс должен содержать множину конструкторов для создания объектов определенного типа (конструктор по замачиванию и с параметрами, конструктор копии) и Класс Hugeint (целые числа) Операции: - =, сравнение(<, >), операции над объъектами классу (плюс обезательно операцию присвоения) с использованием механизма перегрузки операций. Написать программу, которая демонстрирует работу из объъектами этого класса. Организовать выведение и введение данных с помощью классов-потоков сin и cout.
кое-что я сам написал, взяв из примера однако, не сумел написать сравнение(<, >), тай вообще нужно как-то организовать программу,помогите плз, еще зеленый, не умею(
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
121
122
123
//HugeInt.h
#include <iostream>
#include <stdlib.h>
using namespace std;
class HugeInt
{
    int*ptr;
    int size;
public:
    HugeInt(int s=10);
    HugeInt(HugeInt &arr);
    virtual~HugeInt();
 
    void Rindomize(int num = 10);
    HugeInt &operator-(HugeInt &arr);
    HugeInt &operator = (HugeInt &arr);
    HugeInt &operator-=(HugeInt &arr);
    HugeInt &operator>(HugeInt &arr);
    HugeInt &operator< (HugeInt &arr);
 
};
 
//HugeInt.cpp
 
#include "HugeInt.h"
 
 HugeInt::HugeInt(int s)
{
    size = s;
    ptr = new int[size];
    for(int i = 0; i < size; i++)
    {
        ptr[i] = 0;
    }
    cout << "Constructor" << endl;
}
//--------------------------------------------------------------------------------
HugeInt::HugeInt(HugeInt& arr)
{ 
    size = arr.size;
    ptr = new int[size];
    for(int i = 0; i < size; i++)
    {
        ptr[i] = arr.ptr[i];
    }
    cout << "Copy Constructor" << endl;
}
//--------------------------------------------------------------------------------
HugeInt& HugeInt::operator-(HugeInt& arr) 
{
    int mins = (size < arr.size) ? size : arr.size;     
    HugeInt temp;
    if(mins == arr.size)
    {
        temp = *this;
        for(int i = 0; i < mins; i++)
        {       
            temp.ptr[i] -= arr.ptr[i];
        }
    }
    else
    {   
        temp = arr;
        for(int i = 0; i < mins; i++)
        {       
            temp.ptr[i] -= ptr[i];
        }       
    }
    cout << "Operator -" << endl;
    return temp;
}
 
//--------------------------------------------------------------------------------
HugeInt::~HugeInt()
{
    delete[] ptr;
    cout << "Destructor" << endl;
}
//--------------------------------------------------------------------------------
void HugeInt::Rindomize(int num)
{   
    for(int i = 0; i < size; i++)
    {
        ptr[i] = rand() % num;
    }   
}
//--------------------------------------------------------------------------------
HugeInt&HugeInt::operator= (HugeInt& arr)
{
    if(this != &arr)
    {
        delete[] ptr;
        size = arr.size;
        ptr = new int[size];
        for(int i = 0; i < size; i++)
        {
            ptr[i] = arr.ptr[i];
        }
    }
    cout << "Operator =" << endl;
    return *this;
}
//--------------------------------------------------------------------------------
HugeInt& HugeInt::operator-= (HugeInt& arr)
{
    HugeInt temp;
    temp = *this - arr;
    *this = temp;
    return *this;
}
 
//Main.cpp
 
#include "HugeInt.h"
int main()
{
    HugeInt a(5);
    a.Rindomize(5);
    HugeInt b(7);
    b.Rindomize(7);
 
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru