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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Перегрузка операторов в C++ http://www.cyberforum.ru/cpp-beginners/thread810100.html
Помогите правильно перегрузить операторы языка C++. Клиент-программа для работы с комплексными числами должна выглядеть вот так: #include <iostream> #include "matik.h" int main() { using std::cout; using std::cin; Complex a (3.0, 4.0); Complex c; cout << "Enter a complex number (q to quite): ";
C++ Обучение. Книги. Образование. Наверстать упущенное Доброго времени суток уважаемые программисты и сисадмины! Учусь на 1-ом курсе, есть такой предмет, как программирование, во втором семестре пропустил достаточно много тем, теперь не могу понять и догнать группу. Работать с голыми лекциями не получается, не понимаю. Прошли следующие темы: 1) Сортировки 2) Поиск Элемента 3) Структуры 4) Классы 5) Обработка файлов (txt и бинарные) 6) Списки... http://www.cyberforum.ru/cpp-beginners/thread810040.html
C++ Посчитать сумму элеметов периметра массива,что не так?
#include <iostream> #include <stdlib.h> #include <time.h> #define maximum 100 using namespace std; /*Посчитать сумму элементов периметра двухмерной матрицы*/ int main()
C++ Массив: вывести 1й положительный и последний отрицательный элемент массива
Нужно вывести 1й положительный и последний отрицательный элемент массива.И посчитать сумму элементов между ними. Не могу посчитать сумму э-ов между ними( #include <iostream> #include <conio.h> #include <math.h> #include <clocale> // поддержка русского языка #include <stdlib.h>
C++ Вычисление значений неэлементарной функции y = f(x). http://www.cyberforum.ru/cpp-beginners/thread810019.html
Составить программу для вычисления значения неэлементарной функции y = f(x). Реализовать решение несколькими способами: 1) полное ветвление; 2) краткая форма ветвления с использованием составных логических выражений; 3) с использованием условной операции. Подобрать самостоятельно значения входных данных, демонстрирующие правильность работы программы. Количество тестов должно быть не менее 7...
C++ Почему CUDA медленнее на простом коде? Добрый день! Написал простую программу сравнения многократного запуска на CUDA и на CPU Однако CUDA показывает 4539 мс на 1 миллион циклов, а CPU 1580 мс Почему CUDA медленнее на простом коде // Ядро исполнения на GPU __global__ void kernel(float *ex, float *v, float *hi, float *low, float *cl, int m) { int i = blockIdx.x * blockDim.x + threadIdx.x; подробнее

Показать сообщение отдельно
Кот Ангенс
 Аватар для Кот Ангенс
317 / 267 / 37
Регистрация: 24.05.2012
Сообщений: 629
16.03.2013, 19:51     Класс - концентрические окружности
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;
}
 
Текущее время: 02:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru