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

Типы данных в ООП - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти максимальный элемент в каждом парном столбце ? http://www.cyberforum.ru/cpp-beginners/thread537853.html
я сделал программу для поиска по всей матрице , а вот как сделать так чтобы в каждом парном столбце не знаю
C++ Написать сумму всех верхних диагоналей матрицы, параллельной главной подскажите как мне написать сумму всех верхних диагоналей параллельной главной,вот я уже написал сумму всех нижних диагоналей диагоналей параллельной главной s=0; for(j=0;j<m-i;j++) s=s+a; а... http://www.cyberforum.ru/cpp-beginners/thread537843.html
C++ Считать из файла текст и записать его в переменные
Такая задача. Нужно из пакпи где находится бинарник зайти в другую папку(она находиться в этой дирриктории) и считать от туда текст и записать в переменную. Только считывать нужно не весь файл, а...
Castы. Как преобразовать объект. C++
Здравствуйте, скажем у меня есть 2 класса: class a; class b : public a; И такой код a *object = new b; Как лучше преобразовать этот объект обратно в класс а: с помощью static_cast или...
C++ Осуществить ввод с клавиатуры в символьный массив со всеми пробелами, знаками препинания и т.д. http://www.cyberforum.ru/cpp-beginners/thread537829.html
1) Как осуществить ввод с клавиатуры в символьный массив со всеми пробелами, знаками препинания и т.д.? 2) И еще вопрос есть такой. Пытаюсь ввести данные из файла при помощи input.getline(string,...
C++ Классы в C++. Переворот дроби. Есть задачку не могу сделать помогите , нужно написать класс по такому принципу #include <iostream> using namespace std; class rational { private: int a; int b; public: // default... подробнее

Показать сообщение отдельно
soon
2541 / 1306 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
03.04.2012, 18:44
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
#include <iostream>
#include <cstdlib>
#include <algorithm>
#include <stdexcept>
#include <cstring>
////////////////////////////////////////////////////////////////////////////////
template <class T>
class Foo
{
    std::size_t _size;
    std::size_t _realSize;
    T*          _arr;
    //--------------------------------------------------------------------------
    static const std::size_t STEP = 50;
    //--------------------------------------------------------------------------
public:
    explicit Foo(const std::size_t& size):
        _size(size),
        _realSize(STEP > size ? STEP : size + STEP),
        _arr(new T[_realSize])
    {
 
    }
    //--------------------------------------------------------------------------
    explicit Foo(): Foo(0)
    {
 
    }
    //--------------------------------------------------------------------------
    ~Foo()
    {
        delete[] _arr;
    }
    //--------------------------------------------------------------------------
    void push_back(const T elem)
    {
        if(_size == _realSize)
        {
            T* tmp = new T[_realSize];
            std::memcpy(tmp, _arr, _realSize * sizeof(T));
            delete[] _arr;
            _arr = new T[_realSize + STEP];
            std::memcpy(_arr, tmp, _realSize * sizeof(T));
            delete[] tmp;
            _realSize += STEP;
        }
        _arr[size++] = elem;
    }
    //--------------------------------------------------------------------------
    T& at(const std::size_t pos) const
    {
        if(_size > pos)
            return _arr[pos];
        else
            throw std::out_of_range("pos >= size");
    }
    //--------------------------------------------------------------------------
    const std::size_t size() const
    {
        return _size;
    }
    //--------------------------------------------------------------------------
    const Foo<T> operator+ (const Foo<T>& f)
    {
        Foo<T> ret(std::max(f.size(), _size));
 
        const std::size_t min = std::min(f.size(), _size);
        const std::size_t max = std::max(f.size(), _size);
 
        for(std::size_t i = 0; i < min; ++i)
            ret.at(i) = _arr[i] + f.at(i);
 
        for(std::size_t i = min; i < max; ++i)
            ret.at(i) = _arr[i];
 
        for(std::size_t i = min; i < max; ++i)
            ret.at(i) = f.at(i);
 
        return ret;
    }
    //--------------------------------------------------------------------------
    Foo& operator= (const Foo& f)
    {
        _size = f.size();
        if(_realSize)
            delete[] _arr;
        _realSize = f._realSize;
        _arr = new T[_realSize];
        std::memcpy(_arr, f._arr, _realSize * sizeof(T));
    }
};
////////////////////////////////////////////////////////////////////////////////
int main()
{
    Foo<int> f1(3);
    Foo<int> f2(5);
    for(std::size_t i = 0; i < 3; ++i)
        f1.at(i) = i;
    for(std::size_t i = 0; i < 5; ++i)
        f2.at(i) = i * 2;
    Foo<int> f3 = f1 + f2;
    for(std::size_t i = 0; i < 5; ++i)
        std::cout << f3.at(i) << " ";
    std::cout << std::endl;
    return 0;
}
2
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru