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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.89
Ната
0 / 0 / 0
Регистрация: 31.03.2009
Сообщений: 3
#1

одномерный массив, вектор, конструкторы, диструкторы - C++

31.03.2009, 13:44. Просмотров 1211. Ответов 1
Метки нет (Все метки)

Помогите написать программу, определяющую максимальное, минимальное и среднее значение в одномерном массиве целого типа. Используя понятие класса, сознать новый тип данных - вектор. Предусмотреть: 1) динамическое выделение памяти под вектор (конструктор) 2) освобождение памяти после использования объекта (диструктор), обработку оформить в виде отдельных функций членов
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.03.2009, 13:44     одномерный массив, вектор, конструкторы, диструкторы
Посмотрите здесь:
C++ ООП Одномерный массив - вектор
C++ Как передать массив (двумерный/одномерный вектор) в функцию?
C++ Реализовать класс Одномерный массив (вектор) вещественных чисел; перегрузить указанные операции
Описать класс одномерный массив (вектор) целых чисел. Перегрузить следующую операцию: > уменьшить элементы вектора на заданное значение C++
C++ Обработать очень длинный одномерный вектор
Написать класс «массив» (В классе реализовать следующие методы: конструкторы (по умолчанию, с параметрами,) C++
C++ Задан вектор X[20]. Положительные числа переписать в массив Y, а отрицательные в массив W
C++ Задан вектор X[20]. Положительные числа переписать в массив Y, а отрицательные в массив W
C++ Массив и вектор
Вектор и Массив C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ISergey
Maniac
Эксперт С++
1372 / 883 / 52
Регистрация: 02.01.2009
Сообщений: 2,652
Записей в блоге: 1
31.03.2009, 16:47     одномерный массив, вектор, конструкторы, диструкторы #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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#include <iostream>
#include <cassert>
using namespace std;
 
class cvector
{
public:
    cvector():m_data(0),m_size(0){}
 
    cvector(int _size):m_size(_size){
        m_data = new int[m_size];
        zerro();
    }
 
    cvector(const cvector& rhs):m_data(0),m_size(0){
        *this = rhs;
    }
 
    ~cvector(){
        if(m_data){
            delete[] m_data;
        }
        m_size = 0;
    }
 
    int size() const { return m_size; }
 
    int max()  const {
        assert(m_data);
        int _max = m_data[0];
 
        for(int i = 1; i < m_size; ++i)
            if(_max < m_data[i]) _max = m_data[i]; 
 
        return _max;
    }
 
    int min()  const {
        assert(m_data);
        int _min = m_data[0];
 
        for(int i = 1; i < m_size; ++i)
            if(_min > m_data[i]) _min = m_data[i]; 
 
        return _min;
    }
 
    float sred() const {
        float sr = 0;
        for(int i = 0; i < m_size; ++i)
            sr += m_data[i];
        return sr/m_size;
    }
 
    cvector& operator =(const cvector& rhs){
        assert(rhs.m_data && rhs.m_size);
 
        if(m_data)
            delete[] m_data;
    
        m_size = rhs.m_size;
        m_data = new int[m_size];
        for(int i = 0; i < m_size; ++i)
            m_data[i] = rhs.m_data[i];
 
        return *this;
    }
 
    int &operator[](int i){
        assert(i < m_size && i >= 0);
        return m_data[i];
    }
 
private:
    void zerro(){
        if(m_data){
            for(int i = 0; i < m_size; ++i)
                m_data[i] = 0;
        }
    }
 
private:
    int *m_data;
    int m_size;
};
 
int main()
{
    cvector vec(4);
    vec[0] = -1;
    //vec[1] = 0;
    vec[2] = 10;
    vec[3] = 15;
    cout<<vec[0]<<" "<<vec[1]<<" "<<vec[2]<<" "<<vec[3]<<endl;
    cout<<"size: "<<vec.size()<<endl;
    cout<<"min : "<<vec.min()<<endl;
    cout<<"max : "<<vec.max()<<endl;
    cout<<"sred: "<<vec.sred()<<endl;
 
    //cvector v; //v.size == 0 and v.m_data == NULL;
    //vec = v;     error;
    //vec[5] = 1;  error;
    //vec[-1] = 1; error;
    //cout << v.min() <<endl; errer;
 
    cvector v(vec);
    cout<<v[0]<<" "<<v[1]<<" "<<v[2]<<" "<<v[3]<<endl;
 
    return 0;
}
Yandex
Объявления
31.03.2009, 16:47     одномерный массив, вектор, конструкторы, диструкторы
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru