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

Свой класс в С++ - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Упорядочить все строки матрицы по числу элементов, кратных 3 http://www.cyberforum.ru/cpp-beginners/thread533599.html
Упорядочить все строки матрицы по числу элементов, кратных 3, т.е. на первое место поставить строку с наименьшим числом таких элементов и тд., на последнее место - с наибольшим числом таких элементов. остановился на том, что подсчитал количество таких элементов в каждой строке, записал в отдельный массив и отсортировал по возрастанию. А вот как поменять строки местами? {int a =...
C++ Удалить из массива "лишние" (кроме первого) элементы #include "stdafx.h" #include<conio.h> #include<stdio.h> #include<iostream> #include<iomanip> using namespace std; /* Отсев. Задан массив из n элементов. Удалить из массива "лишние" (кроме первого) элементы так что бы оствшиеся образовали http://www.cyberforum.ru/cpp-beginners/thread533578.html
Найти ошибку в коде C++
#include <iostream.h> #include <conio.h> #include <stdio.h> #include <windows.h> using namespace std; void main (void) {
C++ класс Vector
Задание: Разработать класс вектор. Реализовать метод доступа к элементам вектора. Реализовать операции сложения, вычитания, скалярного произведения векторов, а также нахождение модуля вектора.
C++ Создайте структуру Параллелограмм с элементами a, b - стороны параллелограмма и a - угол между сторонами. http://www.cyberforum.ru/cpp-beginners/thread533545.html
Создайте структуру Параллелограмм с элементами a, b - стороны параллелограмма и a - угол между сторонами. Для К заданных фигур определить kl - количество квадратов и k2 - количество прямоугольников. Мне нужно, пожалуйста еще бы пояснения как это делается))
C++ Создайте структуру Конус с элементами - r - основание круга-основания, h - высота конуса. Создайте структуру Конус с элементами - r - основание круга-основания, h - высота конуса. Определить для N заданных конусов объем и площадь поверхности. подробнее

Показать сообщение отдельно
Andersen1313
8 / 8 / 1
Регистрация: 18.10.2010
Сообщений: 120
29.03.2012, 16:05     Свой класс в С++
Пытаюсь сделать класс массива точнее переписать код из учебника, но так как код приводится не целый а кусками то что в данный момент разбирается с трудом понимаю куда что вписывать и в конце написано создайте заголовочный файл и файл .cpp

Сохранил эти файлы создаю проект подключаю свой заголовочный файл и дальше ошибки. Вот что у меня получилось:

Заголовочный файл:
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
class IntArray
{
public:
    //Конструкторы класса
    explicit IntArray (int sz = DefaultArraySize);
    IntArray (int *array, int array_size);
    IntArray (const IntArray &rhs);
 
    //Деструктор класса
    ~IntArray() { delete[] ia; }
 
    //Операции сравнения:
    bool operator== (const IntArray&) const;
    bool operator!= (const IntArray&) const;
    int& operator[] (int index);
 
    //Операции присваиния:
    IntArray& operator= (const IntArray&);
 
    int size() const { return _size; }
    void sort();
 
    int min() const;
    int max() const;
 
    //функция find возвращает индекс первого
    //найденного элемента массива
    //или -1, если элемент не найден
 
    int find (int value) const;
 
private:
    static const int DefaultArraySize = 12;
    int _size;
    int *ia;
 
    void init (int sz,int *array);
};
Файл .cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <cassert>
 
void IntArray::init (int sz, int *array)
{
    _size = sz;
    ia = new int[_size];
 
    for (int ix=0; ix<_size; ++ix)
        if (!array)
            ia[ix] = 0;
        else
            ia[ix] = array[ix];
};
 
IntArray::IntArray (int sz) { init (sz,0); }
IntArray::IntArray (int *array, int array_size) { init (array_size,array); }
IntArray::IntArray (const IntArray &rhs) { init (rhs._size,rhs.ia); }
 
int& IntArray::operator[] (int index)
{
    assert (index >= 0 && index < _size);
    return ia[index];
}
И программа в которой пытаюсь этим пользоваться:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#pragma hdrstop
 
#include <tchar.h>
#include "IntArray.h"
using namespace std;
//---------------------------------------------------------------------------
 
#pragma argsused
int _tmain(int argc, _TCHAR* argv[])
{
    int array0[10];
    IntArray array1[10];
    array1 = array0;
    return 0;
}
Хотелось бы уточнить что из чего надо сохранять из определения класса потому что сделал это как то интуитивно! Все файлы сохранил в одной папке!

Добавлено через 5 часов 12 минут
В общем попробовал все запихнуть все в один файл чтобы проверить какие методы класса работают какие нет, вот что получилось:

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
//---------------------------------------------------------------------------
 
#pragma hdrstop
 
#include <tchar.h>
#include <cassert>
#include <iostream>
using namespace std;
 
//------------------------------------------------------------------------------------------------------------------------------
//\/\/\/КАК МНЕ ЭТО ОПИСАНИЕ КЛАССА ВЫВЕСТИ В ОТДЕЛЬНЫЙ ФАЙЛ, ЧТОБЫ ЧЕРЕЗ #include МОЖНО БЫЛО ПОДКЛЮЧАТЬ\/\/\/
//------------------------------------------------------------------------------------------------------------------------------
class IntArray
{
public:
    //Конструкторы класса
    explicit IntArray (int sz = DefaultArraySize);
    IntArray (int *array, int array_size);
    IntArray (const IntArray &rhs);
 
    //Деструктор класса
    ~IntArray() { delete[] ia; }
 
    //Операции сравнения:
    bool operator== (const IntArray&) const;
    bool operator!= (const IntArray&) const;
    int& operator[] (int index);
 
    //Операции присваиния:
    IntArray& operator= (const IntArray&);
 
    int size() const { return _size; }
    void sort();
 
    int min() const;
    int max() const;
 
    //функция find возвращает индекс первого
    //найденного элемента массива
    //или -1, если элемент не найден
 
    int find (int value) const;
 
private:
    static const int DefaultArraySize = 12;
    int _size;
    int *ia;
 
    void init (int sz,int *array);
};
 
void IntArray::init (int sz, int *array)
{
    _size = sz;
    ia = new int[_size];
 
    for (int ix=0; ix<_size; ++ix)
        if (!array)
            ia[ix] = 0;
        else
            ia[ix] = array[ix];
};
 
IntArray::IntArray (int sz) { init (sz,0); }
IntArray::IntArray (int *array, int array_size) { init (array_size,array); }
IntArray::IntArray (const IntArray &rhs) { init (rhs._size,rhs.ia); }
 
int& IntArray::operator[] (int index)
{
    assert (index >= 0 && index < _size);
    return ia[index];
}
 
//------------------------------------------------------------------------------------------------------------------------------
// ^^^КАК МНЕ ЭТО ОПИСАНИЕ КЛАССА ВЫВЕСТИ В ОТДЕЛЬНЫЙ ФАЙЛ, ЧТОБЫ ЧЕРЕЗ #include МОЖНО БЫЛО ПОДКЛЮЧАТЬ^^^
//------------------------------------------------------------------------------------------------------------------------------
 
#pragma argsused
int _tmain(int argc, _TCHAR* argv[])
{
    int i;
    int array0[10];
    IntArray array1(50);
    IntArray array2(array0,10);
    for (i = 0; i < 10; i++)
        array2[i]=i;
    IntArray array3=array2;
    IntArray array4(10);
    cout << "array1 size: " << array1.size() << "\n";
    cout << "array2 size: " << array2.size() << "\n";
    cout << "array3 size: " << array3.size() << "\n";
    cout << "array4 size: " << array4.size() << "\n";
    system("pause");
    return 0;
}
//---------------------------------------------------------------------------

Все действия работоспособны, все что ожидал получил!

Вопрос остался:
Как вынести класс в отдельный файл???
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:42. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru