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

Создать класс динамического массива - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Найти наибольший и наименьший элементы вещественного массива http://www.cyberforum.ru/cpp-beginners/thread535799.html
Найти наибольший и наименьший элементы вещественного массива. Если таких элементов несколько, определить сколько их. Создать функции для определения максимального и минимального элементов в массиве.
C++ Оставить только повторяющиеся числа Вводится некоторое количество чисел. ввод кончается 0. выбросить все повторяющиеся числа вот рабочая программа Код C++ #include <set> #include <algorithm> #include <iostream> http://www.cyberforum.ru/cpp-beginners/thread535797.html
C++ В заданном массиве из n элементов отсортировать по возрастанию его часть
Здравствуйте! В заданном массиве из n элементов отсортировать по возрастанию его часть, находящуюся между двумя введенными номерами. Массив формируется из случайных чисел в диапазоне от –100 до 100, номера вводятся как два целых числа, не большие чем n
C++ двумерные массивы, cоздание,вывод, сумма,cортировка
Написать следущие процедуры обработки квадратной матриы nxn где n- нечетное, вызов процедру организовать с помощью меню в основной программе 1) создать матрицу заполнив ее по cхеме цифрами от 1 до n^2( схему прикрепила к сообщению) 2) создать матрицу с помощью функции random 3)найти сумму элементов матрицы расположенных над побочной диагональю в верхней половине матрицы 4)упорядочить строки...
C++ Структуры в С++. Списки участников олимпиады. http://www.cyberforum.ru/cpp-beginners/thread535785.html
Всем доброго времени суток!!! Народ помогите у меня такая вот проблема!! Задание звучит вот так: В одном списке инф. про студентов что принимали участие в олимпиаде по информатике, а в другом по математике.Сформулируйте третий список в котором будет содержаться инф. о ст-х которые участвовали в обеих олимпиадах! Вот я набросал код но чтото он сильно при компиле матюкаеться! ...
C++ Надо исправить программу, пожалуйста. Задание: заменить заданное слово в строке другим заданным словом Задание: заменить заданное слово в строке другим заданным словом Вот какие баги, если можно так выразиться, я нашёл: 1. Программа ищет не только слово, но и части слов, что не правильно. Например: строка this is, программа, когда вы введете, что надо заменять is на, допустим, KUKU, программа заменит следующим образом: thKUKU KUKU. 2. И еще проблема возникает, когда слово последнее в строке:... подробнее

Показать сообщение отдельно
igorrr37
 Аватар для igorrr37
1593 / 1221 / 118
Регистрация: 21.12.2010
Сообщений: 1,868
Записей в блоге: 7
01.04.2012, 15:47     Создать класс динамического массива
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
124
125
126
127
#include <iostream>
#include <initializer_list>
#include <algorithm>
#include <stdexcept>
#include <iterator>
#include <fstream>
 
template<typename T>
class Array
{
private:
    T* par;
    std::size_t parSize;
public:
    typedef T value_type;
    Array() : par(nullptr), parSize(0){}
    Array(std::initializer_list<T> l) : parSize(l.size()), par(new T[l.size()])
    {
        std::copy(l.begin(), l.end(), par);
    }
    Array(const Array& ar) : parSize(ar.parSize), par(ar.par ? new T[ar.parSize] : nullptr)
    {
        if(par)
        {
            std::copy(ar.par, ar.par + ar.parSize, par);
        }
    }
    Array(Array&& ar) : parSize(ar.parSize), par(ar.par)
    {
        ar.par = nullptr;
    }
    Array& operator=(const Array& ar)
    {
        if(this != &ar)
        {
            parSize = ar.parSize;
            delete[] par;
            if(!ar.par) par = nullptr;
            else
            {
                par = new T[ar.parSize];
                std::copy(ar.par, ar.par + ar.parSize, par);
            }
        }
        return *this;
    }
    Array& operator=(Array&& ar)
    {
        std::cout << "Move operator=()\n";
        parSize = ar.parSize;
        delete[] par;
        par = ar.par;
        ar.par = nullptr;
        return *this;
    }
    T& operator[](std::size_t ind)
    {
        if(ind >= parSize) throw std::out_of_range("given index >= parSize");
        else return par[ind];
    }
    const T& operator[](std::size_t ind) const
    {
        if(ind >= parSize) throw std::out_of_range("given index >= parSize");
        else return par[ind];
    }
    void push_back(const T& val)
    {
        ++parSize;
        T* pTmp = par;
        par = new T[parSize];
        std::copy(pTmp, pTmp + parSize - 1, par);
        delete[] pTmp;
        par[parSize - 1] = val;
    }
    std::size_t size() const
    {
        return parSize;
    }
    const T* data() const
    {
        return par;
    }
    virtual ~Array()
    {
        delete[] par;
    }
};
 
template<class T>
std::istream& operator>>(std::istream& is, Array<T>& ar)
{
    std::copy((std::istream_iterator<T>(is)), std::istream_iterator<T>(), std::back_inserter<Array<T>>(ar));
    return is;
}
 
template<class T>
std::ostream& operator<<(std::ostream& os, const Array<T>& ar)
{
    std::copy(ar.data(), ar.data() + ar.size(), std::ostream_iterator<T>(os, "  "));
    return os;
}
 
int main()
{
    Array<int> ar1{11, 21, 31}, ar2(ar1);
    ar2 = Array<int>{22, 23, 24, 25};
    ar2.push_back(100);
    ar2.push_back(105);
    std::cin >> ar2;
    std::cout << "ar2 : "<< ar2 << std::endl;
    std::ifstream ifs("1.txt");
    if(ifs)
    {
        ifs >> ar2;
        std::cout << ar2 << std::endl;
    }
    else std::cerr << "Can't open in file\n";
    ifs.close();
    std::ofstream ofs("2.txt");
    if(ofs)
    {
        ofs << ar2;
    }
    else std::cerr << "Can't open out file\n";
    ofs.close();
    return 0;
}
 
Текущее время: 23:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru