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

Не могу перегрузить [] в производном классе - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Switch-case http://www.cyberforum.ru/cpp-beginners/thread862879.html
Можно ли так писать? switch (simvol) { case (('(') or ('1') or ('2') or ('3') or ('4') or ('5') or ('6') or ('7') or ('8') or ('9')): { T(FpReed,FpWrite); Esp(FpReed,FpWrite); break; }
C++ Сформировать массив размером 6 на 3 по правилу программа формирования и вывода массива размером 6 на 3, каждые три последовательных элемента в строке которого составлены по следующему правилу: 1-й - равен удвоенному числу, введенному с клавиатуры; 2-й - равен квадрату суммы индексов предыдущего элемента; 3-й - равен остатку от деления индекса текущего элемента на 2. http://www.cyberforum.ru/cpp-beginners/thread862874.html
C++ Двухмерный массив: вычислить для каждого вопроса проценты ответов «Да», «Нет», «не знаю»
В двухмерном массиве размером n x m хранятся результаты опроса n человек на m вопросов. Ответами на вопросы являются слова «Да», «Нет», «не знаю». программу, указывающую для каждого вопроса проценты ответов «Да», «Нет», «не знаю».
C++ Ошибка в коде
Я уже пол дня код пишу. Дописался до такой степени что уже не хочет компилироваться. Ругаеться на 134 135 строки, но я не вижу там ошибики. Помогите разобраться, а то бошка уже почти не варит. #include <iostream> #include <string> #include <conio.h> using namespace std; enum CATEGORY{family, sport, cabrio, jeep}; class DATE
C++ Задача на динамические структуры данных http://www.cyberforum.ru/cpp-beginners/thread862841.html
Прошу помочь с выполнением задания. Дан одномерный динамический массив А, размер которого вводится и заранее неизвестен. Сформировать динамическую матрицу, в которой первая строка содержит элементы массива А, вторая строка – эти же элементы во второй степени, третья строка – в третьей степени и т.д. Количество строк матрицы вводится. При выполнении задания использовать массивы или матрицы,...
C++ Рекурсия: вычисление количества четных элементов в целочисленном массиве Задание: Написать рекурсивную функцию вычисления количества четных элементов в целочисленном массиве {a} где i=1,2,3.......n Не могу понять как тут представить рекурсивную функцию. сделал набросок, но не думаю, что он правильный. просьба исправить код с++: int sum(int a,int n,int p) {int i; for (i=1;i<=n;i++) if (a%2=0) p=p+1; } подробнее

Показать сообщение отдельно
MarVaL
С++ Beginner
 Аватар для MarVaL
116 / 116 / 16
Регистрация: 28.02.2013
Сообщений: 246
12.05.2013, 21:11     Не могу перегрузить [] в производном классе
Не могу перегрузить оператор [] в производном классе



class_arr.cpp
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
 
#include "IntArray.h"
#include "IntArrayRC.h"
 
void swap(IntArray& ia, int ix, int jx) {
    int tmp = ia[ix];
    ia[ix] = ia[jx];
    ia[jx] = tmp;
}
 
int main() {
    int array[4] =  {1, 2, 3, 4};
    IntArray ia1(4, array);
    IntArrayRC ia2(array, 4);
    swap(ia1, 1, 3);
    
    swap(ia2, 1, 3);
    return 0;
}



IntArray - базовый класс(интерфейс)
Кликните здесь для просмотра всего текста
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
#ifndef INTARRAY_H
#define INTARRAY_H
 
class IntArray {
public:
    explicit IntArray(int array_size = defaultArraySize);
    IntArray(int array_size, int *array);
    IntArray(const IntArray&);
    virtual ~IntArray() { delete[] ia; }
    
    virtual int& operator[](int index) const;
    
    int size() const { return _size; }
    //virtual int find(int index) const;
    //virtual int min() const;
    //virtual int max() const;
    //virtual void sort();
    
    virtual void view();
protected:
    static const int defaultArraySize = 10;
    int *ia;
    int _size;
    void init(int array_size, int *array);
};
 
#endif


IntArray - реализация
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <cassert>
 
#include "IntArray.h"
 
void IntArray::view() {
    for(int ix = 0; ix < _size; ++ix)
        std::cout << ia[ix] << ' ';
}
 
int& IntArray::operator[](int index) const {
    assert(index >= 0 &&  index < _size);
    return ia[index];
}
 
void IntArray::init(int array_size, int *array) {
    _size = array_size;
    ia = new int[_size];
    
    for(int ix = 0; ix < _size; ++ix) {
        if(!array)
            ia[ix] = 0;
        else
            ia[ix] = array[ix];
    }
}
 
IntArray::IntArray(int array_size) {
    init(array_size, 0);
}
 
IntArray::IntArray(int array_size, int *array) {
    init(array_size, array);
}
 
IntArray::IntArray(const IntArray& rhs) {
    init(rhs._size, rhs.ia);
}


IntArrayRC - производный класс
Кликните здесь для просмотра всего текста
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
#ifndef INTARRAYRC_H
#define INTARRAYRC_H
 
#include <cassert>
 
#include "IntArray.h"
 
class IntArrayRC: public IntArray {
public:
    IntArrayRC(int sz = defaultArraySize);
    IntArrayRC(int *array, int array_size);
    IntArrayRC(const IntArrayRC& rhs);
    
    virtual int& operator[](int index) const;
private:
    void check_range(int ix) const;
};
 
inline IntArrayRC::IntArrayRC(int sz)
    : IntArray(sz) { }
    
int& IntArrayRC::operator[](int index) const {
    check_range(index);
    return ia[index];
}
 
inline IntArrayRC::IntArrayRC(int *array, int array_size)
    : IntArray(array_size, array) { }
 
inline void IntArrayRC::check_range(int ix) const {
    assert(ix >= 0 && ix < _size);
}
 
#endif
Миниатюры
Не могу перегрузить [] в производном классе  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:01. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru