⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 reproducervector.java

📁 经典的货郎担问题解决办法
💻 JAVA
字号:
//-----------------------------------------------------------------------------
//  com.coyotegulch.genetic
//
//  A Package of Generic Tools used in Genetic Algorithms
//
//  ReproducerVector.java
//  version 2.1.0
//
//  Copyright 1996-2001 Scott Robert Ladd. All rights reserved.
//
//  For more information about this program, contact:
//
//      Scott Robert Ladd
//      scott@coyotegulch.com
//      http://www.coyotegulch.com
//
//-----------------------------------------------------------------------------
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the
//
//      Free Software Foundation, Inc.
//      59 Temple Place - Suite 330
//      Boston, MA 02111-1307, USA.
//-----------------------------------------------------------------------------

/*
** This code was modified by Kent Paul Dolan.  See accompanying file
** TravellerDoc.html for status of the modifications for your use.
*/

package com.coyotegulch.genetic;

import java.util.*;

public class ReproducerVector
{
    // list of Reproducer objects
    protected Vector m_reproducers;

    // roulette wheel for choosing Reproducers
    protected RouletteWheel m_chooser;

    // exceptions
    private static final RuntimeException m_err1 = new RuntimeException("empty ReproducerVector");

    // constructor
    public ReproducerVector()
    {
        m_reproducers = new Vector();
        m_chooser     = new RouletteWheel();
    }

    // install a new Reproducer
    public void addReproducer(Reproducer m, float w)
    {
        m_reproducers.addElement(m);
        m_chooser.addWeight(w);
    }

    // select a Reproducer by roulette wheel
    public Reproducer select()
    {
        if (m_reproducers.size() == 0)
            throw m_err1;

        int index = m_chooser.getIndex();
        // System.out.println( "chose reproducer: " + index );
        return (Reproducer)m_reproducers.elementAt(index);
    }

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -