亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

java實現遺傳算法實例分享(打印城市信息)

2019-11-26 15:48:10
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

import java.util.*;
public class Tsp { 
    private String cityName[]={"北京","上海","天津","重慶","哈爾濱","長春","沈陽","呼和浩特","石家莊","太原","濟南","鄭州","西安","蘭州","銀川","西寧","烏魯木齊","合肥","南京","杭州","長沙","南昌","武漢","成都","貴州","福建","臺北","廣州","???,"南寧","昆明","拉薩","香港","澳門"};
    //private String cityEnd[]=new String[34];
    private int cityNum=cityName.length;     //城市個數
    private int popSize = 50;               //種群數量
    private int maxgens = 20000;            //迭代次數
    private double pxover = 0.8;            //交叉概率
    private double pmultation = 0.05;       //變異概率
    private long[][] distance = new long[cityNum][cityNum];
    private int range = 2000;               //用于判斷何時停止的數組區間
    private class genotype {
        int city[] = new int[cityNum];      //單個基因的城市序列
        long fitness;                      //該基因的適應度
        double selectP;                        //選擇概率
        double exceptp;                        //期望概率
        int isSelected;                        //是否被選擇
    }
    private genotype[] citys = new genotype[popSize];
    /**
     *    構造函數,初始化種群
     */
    public Tsp() {
        for (int i = 0; i < popSize; i++) {
            citys[i] = new genotype();
            int[] num = new int[cityNum];
            for (int j = 0; j < cityNum; j++)
                num[j] = j;
            int temp = cityNum;
            for (int j = 0; j < cityNum; j++) {
                int r = (int) (Math.random() * temp);
                citys[i].city[j] = num[r];
                num[r] = num[temp - 1];
                temp--;
            }
            citys[i].fitness = 0;
            citys[i].selectP = 0;
            citys[i].exceptp = 0;
            citys[i].isSelected = 0;
        }
        initDistance();
    }
    /**
     *  計算每個種群每個基因個體的適應度,選擇概率,期望概率,和是否被選擇。
     */
    public void CalAll(){
        for( int i = 0; i< popSize; i++){
            citys[i].fitness = 0;
            citys[i].selectP = 0;
            citys[i].exceptp = 0;
            citys[i].isSelected = 0;
        }
        CalFitness();
        CalSelectP();
        CalExceptP();
        CalIsSelected();
    }
    /**
     *    填充,將多選的填充到未選的個體當中
     */
    public void pad(){
        int best = 0;
        int bad = 0;
        while(true){          
            while(citys[best].isSelected <= 1 && best<popSize-1)
                best ++;
            while(citys[bad].isSelected != 0 && bad<popSize-1)
                bad ++;
            for(int i = 0; i< cityNum; i++)
                citys[bad].city[i] = citys[best].city[i];
                citys[best].isSelected --;
                citys[bad].isSelected ++;
                bad ++;  
            if(best == popSize ||bad == popSize)
                break;
        }
    }
    /**
     *    交叉主體函數
     */
    public void crossover() {
        int x;
        int y;
        int pop = (int)(popSize* pxover /2);
        while(pop>0){
            x = (int)(Math.random()*popSize);
            y = (int)(Math.random()*popSize);
            executeCrossover(x,y);//x y 兩個體執行交叉
            pop--;
        }
    }
    /**
     * 執行交叉函數
     * @param 個體x
     * @param 個體y
     * 對個體x和個體y執行佳點集的交叉,從而產生下一代城市序列
     */
    private void executeCrossover(int x,int y){
        int dimension = 0;
        for( int i = 0 ;i < cityNum; i++)
            if(citys[x].city[i] != citys[y].city[i]){
                dimension ++;
            } 
        int diffItem = 0;
        double[] diff = new double[dimension];
        for( int i = 0 ;i < cityNum; i++){
            if(citys[x].city[i] != citys[y].city[i]){
                diff[diffItem] = citys[x].city[i];
                citys[x].city[i] = -1;
                citys[y].city[i] = -1;
                diffItem ++;
            } 
        }
        Arrays.sort(diff);
        double[] temp = new double[dimension];
        temp = gp(x, dimension);
        for( int k = 0; k< dimension;k++)
            for( int j = 0; j< dimension; j++)
                if(temp[j] == k){
                    double item = temp[k];
                    temp[k] = temp[j];
                    temp[j] = item;
                    item = diff[k];
                    diff[k] = diff[j];
                    diff[j] = item; 
                }
        int tempDimension = dimension;
        int tempi = 0;
        while(tempDimension> 0 ){
            if(citys[x].city[tempi] == -1){
                citys[x].city[tempi] = (int)diff[dimension - tempDimension];
                tempDimension --;
            } 
            tempi ++;
        }
        Arrays.sort(diff);
        temp = gp(y, dimension);
        for( int k = 0; k< dimension;k++)
            for( int j = 0; j< dimension; j++)
                if(temp[j] == k){
                    double item = temp[k];
                    temp[k] = temp[j];
                    temp[j] = item;
                    item = diff[k];
                    diff[k] = diff[j];
                    diff[j] = item; 
                }
        tempDimension = dimension;
        tempi = 0;
        while(tempDimension> 0 ){
            if(citys[y].city[tempi] == -1){
                citys[y].city[tempi] = (int)diff[dimension - tempDimension];
                tempDimension --;
            } 
            tempi ++;
        }
    }
    /**
     * @param individual 個體
     * @param dimension    維數
     * @return 佳點集   (用于交叉函數的交叉點)    在executeCrossover()函數中使用
     */
    private double[] gp(int individual, int dimension){
        double[] temp = new double[dimension];
        double[] temp1 = new double[dimension];
        int p = 2 * dimension + 3;
        while(!isSushu(p))
            p++;
        for( int i = 0; i< dimension; i++){
            temp[i] = 2*Math.cos(2*Math.PI*(i+1)/p) * (individual+1);
            temp[i] = temp[i] - (int)temp[i];
            if( temp [i]< 0)
                temp[i] = 1+temp[i];
        }
        for( int i = 0; i< dimension; i++)
            temp1[i] = temp[i];
        Arrays.sort(temp1);
        //排序
        for( int i = 0; i< dimension; i++)
            for( int j = 0; j< dimension; j++)
                if(temp[j]==temp1[i])
                    temp[j] = i;
        return temp;
    }
    /**
     *    變異
     */
    public void mutate(){
        double random;
        int temp;
        int temp1;
        int temp2;
        for( int i = 0 ; i< popSize; i++){
            random = Math.random();
            if(random<=pmultation){
                temp1 = (int)(Math.random() * (cityNum));
                temp2 = (int)(Math.random() * (cityNum));
                temp = citys[i].city[temp1];
                citys[i].city[temp1] = citys[i].city[temp2];
                citys[i].city[temp2] = temp;
            }
        }     
    }
    /**
     * 打印當前代數的所有城市序列,以及其相關的參數
     */
    public void print(){
    /**
     * 初始化各城市之間的距離
     */
    private void initDistance(){
        for (int i = 0; i < cityNum; i++) {
            for (int j = 0; j < cityNum; j++){
                distance[i][j] = Math.abs(i-j);
            }
        }
    }
    /**
     * 計算所有城市序列的適應度
     */
    private void CalFitness() {
        for (int i = 0; i < popSize; i++) {
            for (int j = 0; j < cityNum - 1; j++)
                citys[i].fitness += distance[citys[i].city[j]][citys[i].city[j + 1]];
            citys[i].fitness += distance[citys[i].city[0]][citys[i].city[cityNum - 1]];
        }
    }
    /**
     * 計算選擇概率
     */
    private void CalSelectP(){
        long sum = 0;
        for( int i = 0; i< popSize; i++)
            sum += citys[i].fitness;
        for( int i = 0; i< popSize; i++)
            citys[i].selectP = (double)citys[i].fitness/sum;
    }
    /**
     * 計算期望概率
     */
    private void CalExceptP(){
        for( int i = 0; i< popSize; i++)
            citys[i].exceptp = (double)citys[i].selectP * popSize;
    }
    /**
     * 計算該城市序列是否較優,較優則被選擇,進入下一代
     */
    private void CalIsSelected(){
        int needSelecte = popSize;
        for( int i = 0; i< popSize; i++)
            if( citys[i].exceptp<1){
                citys[i].isSelected++;
                needSelecte --;
            }
        double[] temp = new double[popSize];
        for (int i = 0; i < popSize; i++) {
//          temp[i] = citys[i].exceptp - (int) citys[i].exceptp;
//          temp[i] *= 10;
            temp[i] = citys[i].exceptp*10;
        }
        int j = 0;
        while (needSelecte != 0) {
            for (int i = 0; i < popSize; i++) {
                if ((int) temp[i] == j) {
                    citys[i].isSelected++;
                    needSelecte--;
                    if (needSelecte == 0)
                        break;
                }
            }
            j++;
        }
    }
    /**
     * @param x
     * @return 判斷一個數是否是素數的函數
     */
    private boolean isSushu( int x){
           if(x<2) return false;
           for(int i=2;i<=x/2;i++)
           if(x%i==0&&x!=2) return false;
           return true;
        }
    /**
     * @param x 數組
     * @return x數組的值是否全部相等,相等則表示x.length代的最優結果相同,則算法結束
     */
    private boolean isSame(long[] x){
        for( int i = 0; i< x.length -1; i++)
            if(x[i] !=x[i+1])
                return false;
        return true;
    }
    /**
     * 打印任意代最優的路徑序列
     */
    private void printBestRoute(){
        CalAll();
        long temp = citys[0].fitness;
        int index = 0;
        for (int i = 1; i < popSize; i++) {
            if(citys[i].fitness<temp){
                temp = citys[i].fitness;
                index = i;
            }
        }
        System.out.println();
        System.out.println("最佳路徑的序列:");
        for (int j = 0; j < cityNum; j++)
        {
            String cityEnd[]={cityName[citys[index].city[j]]};
            for(int m=0;m<cityEnd.length;m++)
            {
                System.out.print(cityEnd[m] + " ");
            }
        }
            //System.out.print(citys[index].city[j] + cityName[citys[index].city[j]] + "  ");
            //System.out.print(cityName[citys[index].city[j]]);
        System.out.println();
    }
    /**
     * 算法執行
     */
    public void run(){
        long[] result = new long[range];
        //result初始化為所有的數字都不相等
        for( int i  = 0; i< range; i++)
            result[i] = i;
        int index = 0;       //數組中的位置
        int num = 1;     //第num代
        while(maxgens>0){
            System.out.println("-----------------  第  "+num+" 代  -------------------------");
            CalAll();
            print();
            pad();
            crossover();
            mutate();
            maxgens --;
            long temp = citys[0].fitness;
            for ( int i = 1; i< popSize; i++)
                if(citys[i].fitness<temp){
                    temp = citys[i].fitness;
                }
            System.out.println("最優的解:"+temp);
            result[index] = temp;
            if(isSame(result))
                break;
            index++;
            if(index==range)
                index = 0;
            num++;
        }
        printBestRoute();
    }
    /**
     * @param a 開始時間
     * @param b   結束時間
     */
    public void CalTime(Calendar a,Calendar b){
        long x = b.getTimeInMillis() - a.getTimeInMillis();
        long y = x/1000;
        x = x - 1000*y;
        System.out.println("算法執行時間:"+y+"."+x+" 秒");
    }
    /**
     *    程序入口
     */
    public static void main(String[] args) {
        Calendar a = Calendar.getInstance(); //開始時間
        Tsp tsp = new Tsp();
        tsp.run();
        Calendar b = Calendar.getInstance(); //結束時間
        tsp.CalTime(a, b);
    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日韩中文在线| 亚洲天堂男人天堂女人天堂| 国产精品视频资源| 国产精品伦子伦免费视频| 国产精品久久久久久久一区探花| 97在线视频精品| 久久久精品中文字幕| 欧美日韩中国免费专区在线看| 欧美在线激情视频| 久久久久久久国产精品| 这里只有精品丝袜| 国语自产精品视频在线看| 91视频免费在线| 欧美日韩人人澡狠狠躁视频| 日韩中文字幕国产| 日本免费久久高清视频| 久久伊人精品一区二区三区| 亚洲第一区在线观看| 色婷婷av一区二区三区在线观看| 久久精品国产免费观看| 91精品国产高清自在线| 亚洲欧美国产一本综合首页| 97超碰蝌蚪网人人做人人爽| 亚洲性无码av在线| 国产精品久久综合av爱欲tv| 91精品久久久久久久久中文字幕| 亚洲国产美女精品久久久久∴| 国产成人97精品免费看片| 亚洲四色影视在线观看| 91免费人成网站在线观看18| 久久亚洲影音av资源网| 日韩在线视频国产| 国产精品白丝jk喷水视频一区| 亚洲人成电影网站| 91av在线网站| 久久人人爽亚洲精品天堂| 尤物九九久久国产精品的特点| 97在线视频观看| 亚洲精品久久7777777| 日韩欧美中文免费| 欧美三级xxx| 国产成人啪精品视频免费网| 欧美成人国产va精品日本一级| 欧美视频在线观看免费网址| 精品亚洲男同gayvideo网站| 欧美在线精品免播放器视频| 国产精品三级久久久久久电影| 欧美日韩中文在线| 91精品国产成人www| 日韩视频免费在线| 日韩电影免费观看在线观看| 亚洲精品91美女久久久久久久| 亚洲人免费视频| 欧美国产在线电影| 日韩国产在线播放| 在线日韩第一页| 欧美日韩激情视频| 色偷偷88888欧美精品久久久| 国产91精品久久久久久久| 萌白酱国产一区二区| 亚洲精品久久久久| 国产精品高清免费在线观看| 久久久久久久久亚洲| 欧美巨猛xxxx猛交黑人97人| 欧美区在线播放| 欧美精品www在线观看| 97视频在线观看网址| 青草青草久热精品视频在线观看| 国产精品白嫩美女在线观看| 亚洲国产精久久久久久久| 日韩有码在线视频| 日韩欧美亚洲成人| 亚洲天堂日韩电影| 97人洗澡人人免费公开视频碰碰碰| 亚洲热线99精品视频| 成人在线国产精品| 亚洲欧美日本伦理| 亚洲成人动漫在线播放| 国产午夜精品全部视频在线播放| 欧美激情精品久久久久久大尺度| 97视频在线看| 国产视频福利一区| 国产精品国产三级国产aⅴ9色| 久久久久北条麻妃免费看| 国产精品久久久久久久久久免费| 国产丝袜精品视频| 国产成人小视频在线观看| 欧美激情一级精品国产| 亚洲精品一区二区久| 97在线视频免费播放| 国产成人精品国内自产拍免费看| 日韩视频在线一区| 亚洲小视频在线| 成人欧美一区二区三区在线| 久久久久久久久久国产精品| 国产一区二区三区在线观看网站| 日本高清视频精品| 91国产视频在线播放| 国产精品免费看久久久香蕉| 91免费高清视频| 日韩精品中文在线观看| 成人妇女免费播放久久久| 久久久91精品国产| 亚洲国产精品网站| 97精品国产aⅴ7777| 97在线视频精品| 亚洲丁香久久久| 九九热这里只有精品免费看| 欧美麻豆久久久久久中文| 日韩高清免费观看| 91九色国产视频| 成人国产在线视频| 91精品国产91久久久久福利| 5566成人精品视频免费| 日韩欧美国产高清91| 91日本在线视频| 亚洲二区在线播放视频| 亚洲成人动漫在线播放| 日韩二区三区在线| 国产成人精品一区二区| 国产精品久久久久久亚洲调教| 亚洲激情在线视频| 国产精品户外野外| 久久成年人视频| 国内精品模特av私拍在线观看| 日韩电影中文字幕在线| 97超级碰在线看视频免费在线看| 国产亚洲精品久久久久动| 成人免费视频xnxx.com| 国产精品综合久久久| 久久久久久久av| 国产精品一区久久| 成人精品在线视频| 国产日本欧美一区二区三区在线| 国产精品一久久香蕉国产线看观看| 国产精品亚洲欧美导航| 亚洲aa在线观看| 91精品国产777在线观看| 久久久久久久999精品视频| 久久69精品久久久久久国产越南| 成人网欧美在线视频| 亚洲电影免费观看高清完整版| 亚洲欧美日韩中文在线制服| 中文字幕亚洲字幕| 91国产一区在线| 欧美激情在线一区| 欧美激情视频在线免费观看 欧美视频免费一| 伊人久久综合97精品| 亚洲精品国产综合区久久久久久久| 欧美视频在线视频| 国产成人精品一区| 亚洲精品在线视频| 欧美日韩国产区| 亚洲国产成人在线视频| 亚洲视频视频在线| 91av视频在线观看| 久久九九有精品国产23| 亚洲欧美国产一本综合首页| 国产成人精品日本亚洲专区61| xxxx性欧美| 欧美激情视频网| 91sa在线看| 欧美日韩免费观看中文| 欧美夫妻性生活xx|