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

Вектор объектов пользовательского класса - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Дан массив А на Н элементов (Н-константа). В массиве найти пять максимальных элементов. http://www.cyberforum.ru/cpp-beginners/thread968648.html
Дан массив А на Н элементов (Н-константа). В массиве найти пять максимальных элементов. Написать программу по шагам. Добавлено через 19 минут Пожалуйста очень важно
C++ Ошибка программы при запуске .exe файла из коммандной строки Доброе Время ! Собсно некорректно работает .exe файл проекта Visual Studio из коммандной строки windows. (Нужно с целью использования параметров argc argv). В программе обычное чтение и запись в файл. При запуске из Visual Studio работает нормально. Argc argv нужно чтобы указывать входной и выходной файл при запуске. При их вводе из коммандной строки вылетает ошибка. Пробовал считывать из... http://www.cyberforum.ru/cpp-beginners/thread968646.html
Проблемы с проверкой введённых данных C++
Никак не могу раобраться с проверкой на ввод числа, символа Которую нужно обязательно добавить Помогите пожалуйста :cry: :sorry: #include <iostream> #include <string> #include <cctype> using namespace std; int main(){
Программа выдает 3 ошибки. Одна из них: IntelliSense: выражение должно быть допустимым для изменения левосторонним значением C++
#include <iostream> #include <locale.h> using namespace std; struct PList { int info; PList *prev, *next; };
C++ Аргумент типа char (*)[1000] несовместим с параметром типа char** http://www.cyberforum.ru/cpp-beginners/thread968589.html
Здравствуйте! Есть вот такая структура: #define max 1000 struct expr { char s; int index; };
C++ Функция realloc Начнем сразу с кода. #include "stdafx.h" #include <iostream> #include <cstdlib> int main(void) { using namespace std; double *g=(double*) calloc(1, sizeof(double*));int i=0;double k; for (i=0;i<6;++i) { подробнее

Показать сообщение отдельно
VUsachev
0 / 0 / 0
Регистрация: 04.10.2013
Сообщений: 7
04.10.2013, 09:38     Вектор объектов пользовательского класса
Привет всем!
Есть класс Automaton, я пытаюсь создать вектор Sample с объектами этого класса, а они ведут себя не так, как я ожидаю - создаются и удаляются до использования и после тоже, причём counter = 0 чаще всего... Похоже, речь о конструкторе копирования, подскажите, как это сделать грамотно, пожалуйста, сам уже иссяк.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
// код из main()
    Automaton::Set_dt(dt); // установка времени шага
    cout << "N=" << N << endl;
    vector<Automaton> Sample(); // вектор автоматов
    Sample.clear();
    //Sample.resize(N);
    for(unsigned i = 0; i < N; ++i)
    {
        Sample.push_back(Automaton());
    }
    cout << "tyt_1" << endl;
    /// Для класса
    for(unsigned i = 0; i < Sample.size(); i++)
    {
        Sample[i].V = V;
        Sample[i].S = S_ij;
        Sample[i].d = D;
        Sample[i].m = mass;
        Sample[i].criterion = criterion;
    }
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
// Automaton.h
#ifndef AUTOMATON_H
#define AUTOMATON_H
#include <vector>
using namespace std;
 
class Automaton
{
public:
    unsigned number; // порядковый номер, от 0
    // координаты центра
    double x;
    double y;
    double z;
    // координаты предыдущего шага
    double preX;
    double preY;
    double preZ;
    // компоненты скорости
    double vx;
    double vy;
    double vz;
    double V; // объём
    double S; // площадь контакта
    double d; // диаметр
    double m; // масса
    double w; // угловая скорость
    double Omega; // угол
    // компоненты силы
    double Fx;
    double Fy;
    double Fz;
    double E_aver; // средняя деформация
    double K; // момент сил (от углов)
    double criterion; // критерий автомата (расстояние между центрами автоматов)
    vector<unsigned> neighbours; // вектор с номерами соседей
 
    Automaton(const Automaton&); // Копирующий конструктор
    //Automaton& operator=(const Automaton&;)
    Automaton();
    ~Automaton();
    void Set_Fxyz(double, double, double); // установить значения силы
    void Calc_Velocity(); // вычисление скорости
    void Set_Velocity(double, double, double); // установить скорость (граничные условия)
    void Calc_Coordinate(); // вычисление координат
    void Save_Coordinate(); // сохранить координаты для следующей итерации
 
    static void Set_dt(double); // установить временной шаг
private:
    static unsigned counter; // счётчик автоматов
    static unsigned dt; // временной шаг
};
#endif // AUTOMATON_H
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
// Automaton.cpp
#include "Automaton.h"
#include <iostream>
 
unsigned Automaton::counter = 0;
unsigned Automaton::dt = 0;
 
Automaton::Automaton(const Automaton& a)
{
    number = a.number;
    x = a.x;
    y = a.y;
    z = a.z;
    preX = a.preX;
    preY = a.preY;
    preZ = a.preZ;
    vx = a.vx;
    vy = a.vy;
    vz = a.vz;
    V = a.V;
    S = a.S;
    d = a.d;
    m = a.m;
    w = a.w;
    Omega = a.Omega;
    Fx = a.Fx;
    Fy = a.Fy;
    Fz = a.Fz;
    E_aver = a.E_aver;
    K = a.K;
    criterion = a.criterion;
    neighbours = a.neighbours;
}
 
Automaton::Automaton(): x(0), y(0), z(0), preX(0), preY(0), preZ(0)
{
    neighbours.clear();
    neighbours.resize(6);
    number = counter;
    counter++;
    Set_Fxyz(0, 0, 0);
    Set_Velocity(0, 0, 0);
    w = 0;
    V = 0; S = 0; d = 0; m = 0; // задаются снаружи
    Omega = 0; E_aver = 0; K = 0;
    std::cout << "Create Automaton number = " << number << endl;
}
 
Automaton::~Automaton()
{
    std::cout << "Delete Automaton" << endl;
    counter--;
    neighbours.clear();
}
 
void Automaton::Set_Fxyz(double f_x, double f_y, double f_z = 0)
{
    Fx = f_x;
    Fy = f_y;
    Fz = f_z;
}
 
void Automaton::Calc_Velocity() // правильно ли с накоплением скорости???
{
    double temp = dt/m;
    vx = vx + Fx*temp;
    vy = vy + Fy*temp;
    vz = vz + Fz*temp;
}
 
void Automaton::Set_Velocity(double v_x, double v_y, double v_z)
{
    vx = v_x;
    vy = v_y;
    vz = v_z;
}
 
void Automaton::Calc_Coordinate()
{
    x += vx*dt;
    y += vy*dt;
    z += vz*dt;
}
 
void Automaton::Save_Coordinate()
{
    preX = x;
    preY = y;
    preZ = z;
}
 
void Automaton::Set_dt(double t)
{
    dt = t;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru