2

您好,我正在尝试使用 C++ 创建遗传算法,并且尝试使用向量作为容器,问题是我不知道如何设置向量的大小,因为向量具有这样的类参数

class population
{
    friend class chromosome;
private:
    int population_number;
    int best_index[2];
    vector <chromosome *> chromosome_population;
public:
    population(int numberOfPopulation);
    population(int numberOfPopulation,int numberOfSynapse);
    ~population();
    int worst_chromosome();
    void mating();
    void crossover(int parent_1,int parent_2);
};

这是人口类,这是染色体类

class chromosome
{
    friend class population;
private:
    int chromosome_id;
    float fitness;
    vector <gen *> gen_chromosome;
public:
    chromosome();
    ~chromosome();
    void fitness_function();
    void mutation_translocation();
    int get_chromosome_size();
};

如何在人口类构造函数中设置向量长度?我尝试使用 vector.pushback 和 vector.resize 但两者都会给我错误,因为参数不匹配。实际上我明白它为什么会出错但我不知道如何匹配向量推回中的参数这是我的人口构造函数

population::population(int numberOfPopulation)
{
    srand (time(NULL));
    population_number = numberOfPopulation;
    for(int a=0;a<population_number;a++)
    {
        chromosome_population.push_back();
    }
    cout<<chromosome_population.size();
    for(int i=0;i<population_number;i++)
    {
        chromosome_population[i]->chromosome_id = i;
        int chromosome_length = rand() % 10 + 1;
        for(int j=0;j<chromosome_length;j++)
        {
            chromosome_population[i]->gen_chromosome[j]->basa_biner = rand()%1;
            chromosome_population[i]->fitness = (rand()%99)+1;
        }
    }
}

如果您还需要任何其他信息,您可以在评论中告诉我,我会添加您需要的信息。之前谢谢。

4

1 回答 1

6

std::vector有几个构造函数,其中一个变体接受要存储在vector.

vectorpopulation构造函数的初始化列表中指定 的大小:

population::population(int numberOfPopulation) :
    population_number(numberOfPopulation),
    chromosome_population(numberOfPopulation)
{
}

给出这种方法,population_number成员变量是不必要的,因为它可以通过chromosome_population.size().

在 will 上指定初始大小vector意味着它包含numberOfPopulation空指针。在访问 中的元素之前,vector您需要创建对象,在这种情况下使用new. 如果元素是可复制的并且不需要多态行为,那么建议使用vector<chromosome>。如果必须在中使用动态分配的元素,vector则必须先分配:

chromosome_population[i] = new chromosome();

并记住delete何时不再需要。

还希望使用一种形式的智能指针而不是原始指针。使用智能指针的一个优点是,当vector<unique_ptr<chromosome>>超出范围时,将为您销毁元素,而无需显式调用delete每个元素。请参阅有哪些可用的 C++ 智能指针实现?有关可用智能指针的有用列表。

请注意,它vector::push_back()接受一个参数,其类型与其元素相同。所以正确的调用push_back()是:

chromosome_population.push_back(new chromosome());

如果您指定 at 构造的初始大小vector,调用push_back()vector.

于 2012-11-19T09:28:40.790 回答