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

Проблемка с инициализацией - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Куда подключить заголовочный файл. http://www.cyberforum.ru/cpp-beginners/thread178803.html
Есть много файлов типа:1.h ... 100.h,1.cpp ... 100.cpp, а также один файл main.cpp. Во всех используются функции из <cmath>. Во все файлы надо прописывать #include <cmath>?
C++ Сумма утроенных непарных чисел с помощью for решить задачу: дано n найти сумму чисел вида i^3- 3in^2 +n тех, которые являются утроенными непарными числами ( кратны 3-м) плиз, хелп :) http://www.cyberforum.ru/cpp-beginners/thread178798.html
C++ значения функции Y(x), суммы S(x) и |Y(x)–S(x)|
помогите плиз... ошибка в том, что не совпадают S(x) и y(x)... по заданию ЛР, они должны совпадать!!! ПРога №1 //--------------------------------------------------------------------------- #include <vcl.h> #include <iostream> #include <math.h> #pragma hdrstop
C++ Незнаю как решить задание
Дано четырехзначное число.Найти: а.)сумму его цифр; б.)произвидение ео цифр. Начал учить С++ только два дня назад!Нужно сделать это в консоле Win32. Как это вообше делать! Зарание благодарен!
C++ Найти сумму ряда с заданной точностью http://www.cyberforum.ru/cpp-beginners/thread178779.html
найти сумму ряда с точностью 0,0001 используя цикл while a=10в степени(-n)*(n-1)! вот мой вариант,но она не работает #include "stdafx.h" #include <iostream> #include <math.h> #include <conio.h> using namespace std;
C++ Найти все простые числа, не превышающие число n, используя решето Эратосфена Дано натуральное число n (n>=2). Найти все простые числа, не превышающие число n, используя решето Эратосфена. Решетом Эратосфена называется следующий метод. Выпишем подряд все целые числа от 2 до n. Первым простым числом является число 2. Подчеркнем его, а все больше него числа, кратные числу 2, вычеркнем. Первым числом в ряду чисел, которые остались, является число 3. Подчеркнем его как простое... подробнее

Показать сообщение отдельно
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
20.10.2010, 04:02     Проблемка с инициализацией
Допустим есть такой класс. Работаем именно с классом Temp, в котором указатель на класса IntArr производный от Int. Итак вопрос. Как наиболее корректно инициализировать элементы вектора? При попытке обычной инициализации заполняется поле IntOb класса Int, а хотелось бы, чтобы заполнялся i-ый элемент вектора.

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
#include <iostream>
#include <vector>
 
class Int
{
public:
    Int()
    {
    }
 
    Int(int Other):IntOb(Other)
    {
    }
 
    ~Int()
    {
    }
    
    const int GetInt() const
    {
        return IntOb;
    }
 
    void SetInt(int s=0)
    {
        IntOb=s;
    }
protected:
    int IntOb;
};
 
class IntArr:public Int
{
public:
    IntArr():Int()
    {
        VecInt.resize(3);
    }
 
    ~IntArr()
    {
    }
    
    Int& operator [] (int i)
    {
        return VecInt[i];
    }
 
    const size_t GetVecSize() const
    {
        return VecInt.size();
    }
    
private:
    std::vector<Int> VecInt;
};
 
class Temp
{
public:
    Temp():S(new IntArr)
    {
    }
 
    ~Temp()
    {
        delete S;
    }
 
    void foo()
    {
        for(int i=0; i<S->GetVecSize(); ++i)
        {
            S[i].//??
        }
    }
private:
    IntArr* S;
};
 
int main()
{
    Temp Ob;
    Ob.foo();
}
Добавлено через 42 минуты
Решил таким методом.

C++
1
2
3
4
5
6
7
    void foo()
    {
        for(size_t i=0; i<S->GetVecSize(); ++i)
        {
            S[0][i].SetInt(i);
        }
    }
Элегантнее я так понимаю получится либо, если не использовать указатели, либо через перегрузку оператора ->. Я прав?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 20:38. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru