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

как привильно создать и вызвать конструктор для массив обьектов - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Генератор случайных чисел. Массив http://www.cyberforum.ru/cpp-beginners/thread686598.html
Суть вот в чём: Создать двумерный массив размерностью 3х3 дабы он заполнялся случайными числами. После это выполнить определённые операции по сложению, либо вычитанию диагоналей или индексов. Подключил библиотеки: #include <stdio.h> #include <stdlib.h> #include <conio.h> #include <locale.h> #include <time.h> #define n 3 // матрица 3х3
C++ В чём может быть ошибка программы? Программа должна читать файл parts.dat что бы создать репорк на основе данных в файле. На дисплай долны выводится: Part Current Amt Number Balance Needed Данные в файле parts.dat: AP123 100 53 75 CB876 150 89 100 PC389 50 12 50 ZN264 164 143 150 http://www.cyberforum.ru/cpp-beginners/thread686593.html
Что можно сказать об этом #include "stdafx.h" C++
За что оно отвечает и где его можно использовать?! Много раз встречал но так и не понял зачем оно! #include "stdafx.h"
Сортировка элементов масива обьектов через перегруженный оператор C++
Всем Добрый вечер. У меня есть класс Planet в main мне нужно создать массив обьектов этого класса. И потом его нужно посортировать по значениям одного из поля обьекта класса. При сортировке не вызываеться мой перегруженный оператор.. class Planet{ public: string name; protected: double diameter; private: int sputniks, number, distance; public: Planet(); Planet(string n,double dia,int...
C++ Очередь с двусторонним доступом http://www.cyberforum.ru/cpp-beginners/thread686574.html
Добрый день. Надо разработать реализации для таких очередей с использованием массивов, указателей и курсоров. Очередь с двусторонним доступом - это список, в котором добавлять и удалять элементы можно с обоих концов. Если возможно будет откомментируйте код пожалуйста.
C++ Считывание obj файла Предыстория:) 2 месяца прошло с тех пор как я застрял на том что не могу згрузить 3D модель в OpenGl проект. Я делал конвертеры ("загрузчики") сам 3 совершенно разные версии. Не помогло. Прошу помощь у вас разработать программу или хотябы алгоритм считывание OBJ файла и преобразовние его в код для OpenGl Задачи: Есть OBJ файл. Строиться по типу: " v X Y Z " много таких строк (вершин)... подробнее

Показать сообщение отдельно
Костя Хута
0 / 0 / 0
Регистрация: 27.10.2012
Сообщений: 22
02.11.2012, 01:39  [ТС]     как привильно создать и вызвать конструктор для массив обьектов
НУ с єтим вроде разобрался,но как массив значений сортировать???
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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
// Mikoliv_4.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <string>
#include<iostream>
#include <conio.h>
using namespace std;
 
class Planet{
public: string name;
protected: double diameter;
private: int sputniks, number, distance;
public:
    Planet();
    Planet(string n,double dia,int sput,int numb,int dist);
 
 int sputnik(int num, double dist )
{
    this->number=num;
    this->distance=dist;
    return number;
}
 void setNumber(int numb)
 {
    number=numb;
 }
 
  void setDiametr(double diam)
 {
    diameter=diam;
 }
 
double getDiametr()
{
    return diameter;
}
     
double getNumber()
{
    return number;
}
 
double sputnik(double d )
{
    return d;
}
 
void sputnik(int dist)
{
    distance=dist;
}
 
};
 
 
Planet::Planet(string n,double dia,int sput,int numb,int dist)
         {
            name=n;
            diameter=dia;
            sputniks=sput;
            number=numb;
            distance=dist;
         }
 
ostream &operator<<(ostream &stream, Planet obj)
{
    stream<<obj.name<<", ";
    stream<<obj.getDiametr()<<", ";
    stream<<obj.getNumber();
    return stream;
}
 
iostream &operator>>(iostream &stream, Planet obj)
{
    stream>>obj.name;
    
    return stream;
}
 
bool operator <(Planet ob1,Planet ob2)
{
    cout<<"  _______  < ________";
    if(ob1.getNumber()<ob2.getNumber())
    {
        return true;
    }else
        return false;
}
 
bool operator >(Planet ob1,Planet ob2)
{
    cout<<"  _______  > ________";
    if(ob1.getNumber() > ob2.getNumber())
    {
        return true;
    }else
        return false;
}
 
 
bool operator ==(Planet ob1,Planet ob2)
{
    if(ob1.getNumber() == ob2.getNumber() && (ob1.getDiametr() == ob2.getDiametr()) && (ob1.name == ob2.name))
    {
        return true;
    }else
        return false;
}
 
///////////////////////////////////////////////
int _tmain(int argc, _TCHAR* argv[])
{
 
    
    Planet ob("Earth",3,4,5,4);
    ob.sputnik(5);
    ob.sputnik(3.25);
    ob.sputnik(4, 6.88);
    cout<<ob;//Виводимо через перевантажений метод
    Planet mars("Mars",3,4,5,4);
    Planet ven("Mars",3,4,5,4);
    cout<<endl;
    if(mars==ven)//Порівнюємо 2 однакових об"єкта
    {
        cout<<"Resul'tat porivnyannya : true"<<endl;
    }
    //оператор порівняння "<" , ">" порівнює кількість спутників кожного об'єкта
    Planet mars1("Mars",3,4,6,4);//6 спутників
    Planet ven1("Venera",3,4,15,4);//15 спутників
    if(mars1<ven1)
    {
        cout<<"mars1 < ven1";
    }
    else if(mars1>ven1)
    {
        cout<<"mars1 > ven1";
    }
 
//  
    Planet* planets[4]={
    new Planet("Aaaa",34,55,3,3),//3 сп
    new Planet("Baaa",33,34,6,3),//6сп
    new Planet("Ccc",33,34,2,3),//2 сп
    new Planet("Rrr",33,34,5,3),//5 сп
    };
 
    
    for (int i=4-1;i>0;i--)
  {
    for (int j=0;j<i;j++)
      {
 
        if(planets[j] < planets[j+1])
          {
              int tmp=planets[j]->getNumber();
              planets[j]=planets[j+1];
              planets[j+1]->setNumber(tmp);
          }
     }
  }
    
    cout << "Your array after sorting: ";
    for ( int i = 0; i < 4; i ++ ){
        cout << planets[i] << " ";
    } 
 
    
    getch();
    return 0;
}
 
Текущее время: 10:32. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru