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

Класс - концентрические окружности - C++

Восстановить пароль Регистрация
 
Starstuck
 Аватар для Starstuck
4 / 4 / 0
Регистрация: 01.02.2012
Сообщений: 124
16.03.2013, 14:35     Класс - концентрические окружности #1
Создать класс CONCENTRIC - концентрические окружности. Члены класса: центр окружностей (двумерная точка XY), массив радиусов, кол-во окружностей. Продемонстрировать работоспособность копирующего конструктора и оператора присваивания. Перегрузить оператор [] и оператор потокового вывода <<. Определить 10 концентрических окружностей с радиусами, возрастающими в арифметической прогрессии
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.03.2013, 14:35     Класс - концентрические окружности
Посмотрите здесь:

Класс "Окружность" с данными центр и радиус окружности. Вычислить длину и площадь окружности. C++
C++ Класс таблиц баз данных и класс записей в таблице(реляционная таблица). Предусмотреть класс связей между таблицами
Класс, производный класс, паблик-класс C++
C++ По заданным координатам центра окружности и ее радиусу определить координаты точек пересечения окружности с осями координат.
Класс "Окружность" с данными центр и радиус окружности. C++
C++ Класс, инкапсулирующий массив окружности
Написать класс, который бы инкапсулировал массив окружности C++
Отдельно класс данных, класс формул и главный класс C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Кот Ангенс
 Аватар для Кот Ангенс
317 / 267 / 37
Регистрация: 24.05.2012
Сообщений: 629
16.03.2013, 19:51     Класс - концентрические окружности #2
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
//concentric.h:
#pragma once
 
#include <initializer_list>
#include <iostream>
 
template <typename _Real = float>
class CONCENTRIC {
    _Real _x, _y;
    unsigned _count;
    _Real* _r;
 
    void _Init(const CONCENTRIC& c) {
        delete[ ] _r;
        _x = c._x;
        _y = c._y;
        _r = new _Real[_count = c._count];
        for (unsigned i = 0; i < _count; i++)
            _r[i] = c._r[i];
    }
 
public:
    //Конструктор по умолчанию
    CONCENTRIC(): _x(0), _y(0), r(nullptr), _count(0) { }
 
    //Конструктор
    CONCENTRIC(const _Real& x, const _Real& y, unsigned count = 0): _x(x), _y(y), _count(count) {
        _r = _count ? new _Real[_count] : nullptr;
    }
 
    //Конструктор из списка инициализации
    CONCENTRIC(const std::initializer_list<_Real>& l): _x(0), _y(0) {
        if (_count = l.size()) {
            _r = new _Real[_count];
            unsigned i = 0;
            for (const auto& a: l)
                _r[i++] = a;
        } else
            _r = nullptr;
    }
 
    //Конструктор копирования
    CONCENTRIC(const CONCENTRIC& c) { _Init(c); }
 
    //Конструктор переноса
    CONCENTRIC(const CONCENTRIC&& c): _x(c._x), _y(c._y), _count(c._count), _r(c._r) { }
 
    //Деструктор
    ~CONCENTRIC() { delete[ ] _r; }
 
    //Оператор присваивания
    CONCENTRIC& operator=(const CONCENTRIC& c) { _Init(c); }
 
    //Оператор доступа по индексу
    _Real& operator[ ](unsigned index) { return r[i]; }
    const _Real& operator[ ](unsigned index) const { return r[i]; }
 
    //Оператор вывода в поток
    friend std::ostream& operator<<(std::ostream& os, const CONCENTRIC& c) {
        os << '(' << c._x << "; " << c._y << "):\n";
        if (c._count) {
            os << *c._r;
            for (unsigned i = 1; i < c._count; i++)
                os << ", " << c._r[i];
        }
        return os << endl;
    }
 
    //Методы, получающие и задающие координаты центра
    _Real X() const { return _x; }
    _Real Y() const { return _y; }
    _Real X(const _Real& x) { return _x = x; }
    _Real Y(const _Real& y) { return _y = y; }
 
    //Методы, получающие и задающие размер массива
    unsigned Count() const { return _count; }
    unsigned Count(unsigned ct) {
        if (ct != _count) {
            auto t = _r;
            if (ct) {
                _r = new _Real[ct];
                unsigned len = _count < ct ? _count : ct;
                for (unsigned i = 0; i < len; i++)
                    _r[i] = t[i];
                _count = ct;
            } else {
                _r = nullptr;
                _count = 0;
            }
            delete[ ] t;
        }
        return _count;
    }
};
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
//main.cpp:
#include "concentric.h"
 
using namespace std;
 
enum { N = 5 };
 
int main() {
    CONCENTRIC c1(2.5, 7.6, N);
    CONCENTRIC c2 = { 1, 2, 3, 4, 5 };
    c2.X(.0);
    c2.Y(.0);
    CONCENTRIC<double> c3(8e-10, 2e-10);
    c3.Count(N);
    for (char i = 0; i < N; i++) {
        c1[i] = i * 2.1;
        c3[i] = i * 1e-10;
    }
    CONCENTRIC c4 = c2;
    c2 = c1;
    cout << c2 << endl << c4 << endl << c3;
}
Yandex
Объявления
16.03.2013, 19:51     Класс - концентрические окружности
Ответ Создать тему
Опции темы

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