C++ OOP vectores de clases - como crear un vector de una clase

Iniciado por GisiNA, 15 Febrero 2017, 15:42 PM

0 Miembros y 1 Visitante están viendo este tema.

GisiNA

Oh!
Funcionó!

Código (cpp) [Seleccionar]

#include <iostream>
#include <string>
#include <vector>

using namespace std;

//Klasse einrichten
class Patient
{
private:
    string fname;
    string sname;

public:
~Patient(){}

Patient(){ }

void setFistname(string _fname)
{ fname = _fname; }

void setSecondname(string _sname)
{ sname = _sname; }

string getSecondname() const { return sname; }
string getFistname() const { return fname; }
};

int main()
{
string _sname, _fname;

vector<Patient>vielePatient;
Patient a;

cout<<"Apellido: ";
cin >> _fname;
a.setFistname(_fname);

cout<<"Nombre: ";
cin >> _sname;
a.setSecondname(_sname);

vielePatient.push_back(a);

for(int i=0; i<=vielePatient.size(); i++)
{
cout << vielePatient[i].getFistname() << " " << vielePatient[i].getSecondname() << endl;
}

return 0;
}

;-)

Ahora me gustaría aprender el cómo hacer lo mismo con el vector en una clase.

GisiNA

Ohh! Funcionó!!  ;-)
Código (cpp) [Seleccionar]

#include <iostream>
#include <string>
#include <vector>

using namespace std;

//Klasse einrichten
class Patient
{
private:
    string fname;
    string sname;

public:
~Patient(){}

Patient(){ }

void setFistname(string _fname)
{ fname = _fname; }

void setSecondname(string _sname)
{ sname = _sname; }

string getSecondname() const { return sname; }
string getFistname() const { return fname; }
};

int main()
{
string _sname, _fname;

vector<Patient>vielePatient;
Patient a;

cout<<"Apellido: ";
cin >> _fname;
a.setFistname(_fname);

cout<<"Nombre: ";
cin >> _sname;
a.setSecondname(_sname);

vielePatient.push_back(a);

for(int i=0; i<=vielePatient.size(); i++)
{
cout << vielePatient[i].getFistname() << " " << vielePatient[i].getSecondname() << endl;
}

return 0;
}



Ahora me gustaría aprender el cómo se hace con el vector dentro de una clase hijo bajo private. :D

Saludos,
Gisi

GisiNA

#12
( :huh: He intentado publicar ya por tercera vez y salgo volando...)

Y funcionó tu corrección!!! ;-)

Código (cpp) [Seleccionar]

#include <iostream>
#include <string>
#include <vector>

using namespace std;

//Klasse einrichten
class Patient
{
private:
   string fname;
   string sname;

public:
~Patient(){}

Patient(){ }

void setFistname(string _fname)
{ fname = _fname; }

void setSecondname(string _sname)
{ sname = _sname; }

string getSecondname() const { return sname; }
string getFistname() const { return fname; }
};

int main()
{
string _sname, _fname;

vector<Patient>vielePatient;
Patient a;

cout<<"Apellido: ";
cin >> _fname;
a.setFistname(_fname);

cout<<"Nombre: ";
cin >> _sname;
a.setSecondname(_sname);

vielePatient.push_back(a);

for(int i=0; i<=vielePatient.size(); i++)
{
cout << vielePatient[i].getFistname() << " " << vielePatient[i].getSecondname() << endl;
}

return 0;
}



Ahora me gustaría aprender hacer lo anterior pero con el vector en una clase hija bajo private.  :D

ivancea96

Todo se reduce a lo mismo. Si es privado, o es porque accedes a él mediante un getter, o es porque es un campo que solo debe conocer la clase. Si tiene el getter, es lo mismo trabajar con él que trabajar con el vector en el main.

De todos modos, no entiendo por qué "clase hija con vector private". Campo privado, clase hija, vector, son 3 conceptos diferentes, y si los manejas los 3, lo puedes combinar como quieras.

GisiNA

Hola!, mira precisamente porque quiero entender a trabajar con esos tres conceptos, pienso que realizar un ejercicio de ese tipo, podría ayudarme.

Este es el ejercicio final que me gustaría poder resolver y así entender la lógica de los tres conceptos que señalas:

Código (cpp) [Seleccionar]



#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <stdio.h>
#include <vector>

using namespace std;

class Patient
{
private:
    string fname;
    string sname;

public:
~Patient(){}

Patient(){ }

void setFistname(string _fname)
{ fname = _fname; }

void setSecondname(string _sname)
{ sname = _sname; }

string getSecondname() const { return sname; }
string getFistname() const { return fname; }
};

class PatientDatenbank : protected Patient
{
   protected:
//vector tipo clase Patient.
    vector<Patient> vielePatient;
   public:
   PatientDatenbank(){}
    //Copia del vector clase Patient
   vector<Patient> GetCopyOfVector()
   { return vielePatient; }

// Escribir en la copia del vector
void patInsert(vector<Patient>& vielePatient)
    {   
         vielePatient.push_back(datenbank);
         cout << endl;
    }

// Imprimir el vector en pantalla
    void printVectorPatientDatenbank(const vector<Patient>& vielePatient)
    {
        int i;
        int size = vielePatient.size();

        for(i=0; i<size; i++)
        {
cout << vielePatient[i].getFistname() << " " << vielePatient[i].getSecondname() << endl;
        }
    }
};

int main()
{
string _sname, _fname;
// Patient patient01;
   PatientDatenbank datenbank;

cout<<"Apellido: ";
cin >> _fname;
// patient01.setFistname(_fname);
datenbank.setFistname(_fname);

cout<<"Nombre: ";
cin >> _sname;
// patient01.setFistname(_sname);
datenbank.setSecondname(_sname);

    return 0;
}



Mi problema radica seguramente en la forma que estoy tratando de acceder al vector. De una parte, pienso que la copia que crea de él está mal. La otra parte que creo errada es la forma en que intento traspasar desde main la información de mi objeto a la clase "PatientDatenbank" que es la que tiene el vector.

El error que recibo es: datenbank no ha sido declarado.

Saludo,
Gisi

ivancea96

El error lo dice todo.
Código (cpp) [Seleccionar]
void patInsert(vector<Patient>& vielePatient)
{   
     vielePatient.push_back(datenbank);
     cout << endl;
}


datenbank no existe. Querrás decir vielePatient. (En cualquier caso, cuidado con llamar a los parámetros igual que a los miembros de la clase)

GisiNA

#16
Hola!
Ya de a poco voy entendiendo mejor los conceptos. Como indicas hice el cambio de los nombres de los parametros.
Ahora bien, database es mi objeto que pretendo almacenar en el vector. maniPatien es el nombe del vector. Por lo que tengo entendido es que la sintaxis de un un push_back es:

NombreVector.push_back(ObjetoAAgregarEnVector);

Yo quiero trapasar mi objeto creado en main database al vector.

Código (cpp) [Seleccionar]

void patInsert(vector<Patient>& database)
   {
        //NombreVector.push_back(ObjetoAAgregarEnVector);
        manyPatient.push_back(database);
        cout << endl;
   }


El objeto database lo tengo creado con la siguiente declaración:

Código (cpp) [Seleccionar]

       // Las variables
string _sname, _fname;
       // Creación objeto database de la clase PatientDatabase
       PatientDatabase database;

       // Se llenan las variables
cout<<"Apellido: ";
cin >> _fname;

cout<<"Nombre: ";
cin >> _sname;

      // Se  traspasa la información de las variables por setter.
database.setName(_fname, _sname);



Quizás, lo que me intentas señalar es que el vector no debería estar colocado en una clase que hereda sino en la misma clase a la que pertenece. Y que por eso el compilador no reconoce al objeto database creado en main.

Es ese error lógico mío que intentas hacerme entender?

Saludos y muchas gracias.

Dejo acá el código completo:

Código (cpp) [Seleccionar]

#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <stdio.h>
#include <vector>

using namespace std;

class Patient
{
protected:
   string fname;
   string sname;

public:
~Patient(){}

Patient(){ }

void setName(string _fname, string _sname)
{ fname = _fname;
 sname = _sname;}

/*void setFirstname(string _fname)
{ fname = _fname; }

void setSecondname(string _sname)
{ sname = _sname; }*/

string getSecondname() const { return sname; }
string getFirstname() const { return fname; }
};

class PatientDatabase : public Patient
{
  private:
//vector tipo clase Patient.
  //vector<Patient> manyPatient;
  public:
  PatientDatabase(){}
  vector<Patient> manyPatient;
  //Copia del vector clase Patient
  /*vector<Patient> GetCopyOfVector()
  { return manyPatient; }*/

// Escribir en la copia del vector
void patInsert(vector<Patient>& manyPatientFull)
   {
        manyPatientFull.push_back(database);
        cout << endl;
   }

// Imprimir el vector en pantalla
   void printVectorPatientDatabase(const vector<Patient>& manyPatientShow)
   {
       int i;
       int size = manyPatientShow.size();

       for(i=0; i<size; i++)
       {
cout << manyPatientShow[i].getFirstname() << " " << manyPatientShow[i].getSecondname() << endl;
       }
   }
};

int main()
{
string _sname, _fname;

       PatientDatabase database;

cout<<"Apellido: ";
cin >> _fname;


cout<<"Nombre: ";
cin >> _sname;


database.setName(_fname, _sname);

   return 0;      
}    



Y acá el error:

Código (cpp) [Seleccionar]

In member function 'void PatientDatabase::patInsert(std::vector<Patient>&)':
prog.cpp:48:10: error: 'manyPatient' was not declared in this scope
         manyPatient.push_back(database);


ivancea96

No existe porque lo has comentado:
Código (cpp) [Seleccionar]
//vector<Patient> manyPatient;

Y push_back es, como dices, para añadir 1 elemento. No puedes añadir un vector a un vector con push_back. Tendrás que usar insert (http://www.cplusplus.com/reference/vector/vector/insert/)
Por ejemplo, para insertarlo al prin
Código (cpp) [Seleccionar]
manyPatient.insert(manyPatient.end(), database.begin(), database.end());

GisiNA

#18
(No, si el error salta con esa parte no comentada. Eliminé el comentario. Lo había colocado, para probar lo que ocurre si dejo el vector en public.)

Ahora bien, efectivamente pretendo no agregar un vector al vector sino un único objeto, a saber el objeto database creado en main.

Porqué cuando tuve el vector en main (algo más arriba está el ejercicio) pude insertar el objeto con push_back y ahora que el vector se encuentra en una clase ya no? :-(


Voy a probar la opción insert.

ivancea96

Me estás diciendo que teiens problemas pero no me estás enseñando el código con esos problemas.

Si tienes un problema, enseña el código que da ese problema, y los errores que genera.