比较std :: find方法中的类对象

时间:2014-02-07 10:20:59

标签: c++ class find

我是c ++编程的新手。我需要在自定义对象的向量中找到一个特定的对象,但是这个向量在另一个类对象中。所以我认为我需要定义一个自定义运算符==但我不知道如何,特别是在哪里。 请帮帮我,我疯了。 希望我的解释清楚。 在我的类的头文件下面。

#ifndef MAGAZZINO_H
#define MAGAZZINO_H

#include <iostream>
#include <string>
#include <vector>
#include "new_farmaco_magazzino.h"
#include "sacca.h"
#include "ricetta.h"
#include <algorithm>




using namespace std;

class farmaco_magazzino;
class sacca;
class ricetta;

struct index_detect{
    int index_large;
    int index_small;
};

struct da_scaricare{
    string ID_drug;
    eLiquid ID_bag;
    int num_vial;
    double capacity;
};

struct possible_scarico{
    vector<farmaco_magazzino> vial_large;
    vector<farmaco_magazzino> vial_small;
    vector<sacca> sacche_large;
    vector<sacca> sacche_small;
};

class magazzino {

public:

   vector<farmaco_magazzino> lista_small;
   vector<farmaco_magazzino> lista_large;
   vector<sacca> SaccheSmall; 
   vector<sacca> SaccheLarge;

   int new_capienza_SaccheLarge; //indica il numero di postazioni totali per le    sacche large
   int new_capienza_SaccheSmall; //indica il numero di postazioni totali per le sacche small
   int new_capienza_SiringheLarge; //indica il numero di postazioni totali per le siringhe large
   int new_capienza_SiringheSmall; //indica il numero di postazioni totali per le siringhe small
   int new_capienza_VialLarge; // indica il numero di postazioni totali per i vial large
   int new_capienza_VialSmall; // indica il numero di postazioni totali per i vial small

   int pos_disp_FarmacoLarge;
   int pos_disp_FarmacoSmall;
   int pos_disp_SaccheLarge;
   int pos_disp_SaccheSmall;
   int pos_disp_SiringheLarge;
   int pos_disp_SiringheSmall;

   //scarico possibile sulla base dei mismatch valido per magazzino di stoccaggio
   possible_scarico download;


   //default constructor
   magazzino();
   //overload constructor
   magazzino(int);
   //destructor
   ~magazzino();

   //accessor function
   int getNum_sacche(string); //restituisce il numero di sacche contenute nel magazzino
   //int getPos_totali(); //restituisce la capienza del magazzino
   int get_NumSiringhe(string);//restituisce il numero di siringhe contenute nel magazzino
   int getPos_disponibili(string,string); //restituisce le postazioni disponibili del magazzino
   //void setPos_disponibili(int);

   //mutator function
   void setNum_sacche(string,int);
   void setNum_siringhe(string,int);
   void update_magazzino(double*,vector<index_detect>&,magazzino&,string);//per magazzino interno
   bool update_magazzino(ricetta&,vector<index_detect>&,magazzino&,magazzino&,string);// per magazzino stoccaggio
   void load_magazzino(magazzino&,string,double,double,string,string,int);//carico magazzino interno
   void load_magazzino(magazzino&,string,double,string,string,int);// carico magazzino stoccaggio
   int postazioni_libere(int,vector<farmaco_magazzino>&);
   int num_object(int,int); // calcola il numero di sacche/siringhe contenute nel magazzino
   bool use_vial(double*,magazzino&,int,string); //per magazzino interno
   bool use_vial(ricetta&,magazzino&,magazzino&,int,string); //per magazzino stoccaggio
   bool use_bag(double*,magazzino&,int,string);//per magazzino interno
   bool use_bag(ricetta&,magazzino&,magazzino&,int,string);// per magazzino stoccaggio
   bool check_empty(string);
   vector<index_detect> find_lista(magazzino&,string,eContainerType); //trova elemento all'interno della lista dei vials oppure della sacche
   void svuota(magazzino&); //funzione di svuotamento del magazzino interno
   void clear_null(magazzino&,string); //elimina farmaci finiti
   void sorting(vector<double>&); //ordine i vettori di capacità o residual all'interno dello stesso farmaco
   void sorting_bag(vector<sacca>&,string);//ordine i vettori di capacità all'interno del vettore saccche



  // int magazzino::calcolo_pos_libere(int,int,vector<int>); //calcola il numero di postazioni libere
private:
   int new_num_SaccheLarge; // numero di sacche con capacità compresa tra 250cc e 500cc
   int new_num_SaccheSmall; // numero di sacche con capacità <250cc
   int new_NumSiringheLarge; // siringhe da 50ml utilizzate per dispensare farmaco in sacca
   int new_NumSiringheSmall; // siringhe da 5ml utilizzate come contenitore di destinazione


};

bool quantità_nulla(farmaco_magazzino&);


#endif

这是包含2个farmaco_magazzino类型向量的主类,我需要找到一个特定的元素;这里是farmaco_magazzino类的代码。

  #ifndef NEW_FARMACO_MAGAZZINO_H
  #define NEW_FARMACO_MAGAZZINO_H

  #include <iostream>
  #include <string>
  #include "magazzino.h"

  using namespace std;

  enum eContainerType {
      _vial,
      _bag
  };



class farmaco_magazzino {
public:

    // default constructor
    farmaco_magazzino();
    //overload constructor
    farmaco_magazzino(string,double,eContainerType,int);
    // destructor
    ~farmaco_magazzino();

    vector<double> capacity; // capacità dei contenitori in cui è presente il farmaco (vial o bag)
    vector<double> residual; // farmaco residuo nei contenitori di destinazione nel caso del magazzino interno

    //accessor functions

    string get_IDfarmaco(); //restituisce ID farmaco contenuto in magazzino
    double get_quantità_farmaco(); //restituisce quantità di farmaco contenuta in magazzino
    eContainerType get_container_type(); //restituisce il tipo di contenitore in cui è contenuto il farmaco
    int get_num_vials(int); //restituisce il numero di vials di tipo 1/2 dello specifico  farmaco contenuto nel magazzino
    double getPriority(); //restituisce la priorità associata alla presenza in magazzino del farmaco
    int get_vial_used(); //restituisce il tipo di vial utilizzato per la ricetta i-esima

    //mutator functions

    void farmaco_magazzino::setPriority(double);
    void farmaco_magazzino::set_quantità_farmaco(double);
    void farmaco_magazzino::set_num_vials(int); //incrementa il numero di vials di tipo 1 e 2
    void farmaco_magazzino::set_vial_used(int);

    int new_num_Vial;//numero vials 
    //int new_num_VialSmall; //numero vials di tipo small


private:
    string new_IDfarmaco; //definire tipo enum
    double new_quantità_farmaco;
    eContainerType new_container_type; // se farmaco è contenuto in vial oppure in sacca
    double new_priority;
    int new_vial_used;   // new_vial_used=1->vial large; new_vial_used=2->vial small
};


#endif

感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

我建议使用地图而不是矢量。您从get_IDfarmaco获得的ID有望是唯一的,如果是这样,您可以将其用作地图的关键字。 实际上,如果您想使用find,则需要使用地图。因为矢量没有那种方法。或者你正在使用像boost这样的东西?

如果它的stl :: vector,那么你需要迭代向量并自己比较每个对象,如果我没有弄错,那就是O = n。使用地图你会得到O = log(n)