亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? tsp_g.java

?? TSP問題的源代碼及城市信息
?? JAVA
字號:
import java.awt.*;
import java.lang.*;
import java.io.*;
import java.lang.Math;
import javax.swing.*;
import java.util.Random;

/*
 * Created on 2004-10-8
 *
 * TODO To change the template for this generated file go to
 * Window - Preferences - Java - Code Style - Code Templates
 */

/**
 * @author Bluewater
 *
 * TODO To change the template for this generated type comment go to
 * Window - Preferences - Java - Code Style - Code Templates
 */
class TSP_g {

	 double[][] city;
	 int[][] oldparent1={},newparent;
	 int[] bestsequence;
	 int gen,maxgen,citynum,popsize;
	 double pmutation,pcross,pselect;
	 double[] pfitness,poldfitness;
	 public TSP_g()
	 {
	   this.citynum=20;
	   this.popsize=100;
	   bestsequence=new int[citynum];
	   this.pmutation=0.35;
	   this.pcross=1.0;
	   this.pselect=0.2;
	   this.gen=0;
	   this.city=new double[20][2];
	   oldparent1=new int[popsize][citynum];
	   newparent=new int[popsize][citynum];
	   initial(this.citynum);
	   poldfitness=calculate_fitness(oldparent1,this.popsize);
	   while(gen<5)
	   {
	   	for(int i=0;i<popsize;i+=2)
	   	{
	   		cross();
	   		gen++;
	   	}
	   	/*

	   	隨機從P(t)中產生兩個父體交叉操作后產生兩個后代;

	   	把這兩個后代加入中間群體P′(t)中;

	   	}

	   	對中間群體P′(t)中的每個個體進行變異操作;

	   	從P(t)和P′(t)中進行選擇操作得到N個個體賦予新群體P(t+1)中;

	   	計算P(t+1)中每個個體的適應度;

	   	t++;*/
	   }
	 }


	 public void cross()
	 {
	 	Random rr=new Random();
   		double probablity=0.0;
   		int num1,num2,crossposition;
   		num1=0;num2=0;crossposition=0;
   		try
		{
   			probablity=rr.nextDouble();
   			num1=rr.nextInt(popsize-1);
   			num2=rr.nextInt(popsize-1);
   			crossposition=rr.nextInt(citynum-1);
		}
   		catch(IllegalArgumentException ex)
		{
   			ex.printStackTrace();
		}
   		for(int i=0;i<popsize;i++)
   			for(int j=0;j<citynum;j++)
   				newparent[i][j]=oldparent1[i][j];
   		//進行交叉操作
   		if(probablity<=pcross)
   		{
   			crossaction(newparent[num1],newparent[num2],crossposition);
   		}
   		System.out.println("交叉后");
   		calculate_fitness(newparent,popsize);
   		System.out.println("交叉wanbi");
	 }

	 public void crossaction(int[] first,int[] second,int position)
	 {
	 	int i,j;
	 	int[] temp1=new int[citynum];
	 	int[] temp2=new int[citynum];
	 	for(i=0;i<citynum;i++)
	 	{
	 		temp1[i]=first[i];
	 		temp2[i]=second[i];
	 	}
	 	changeorder(temp1,position);
	 	changeorder(temp2,position);
	 	for(i=0;i<position;i++)
	 		for(j=0;j<citynum;j++)
	 		{
	 			if(temp2[j]==first[i])
	 				temp2[j]=-1;
	 			if(temp1[j]==second[i])
	 				temp1[j]=-1;
	 		}
	 	int position_num=position;
	 	for(i=0;i<citynum;i++)
	 	{
	 		if(temp2[i]!=-1)
	 			{first[position_num]=temp2[i];
	 			 position_num++;
	 			}
	 		if(temp1[i]!=-1)
	 			{second[position]=temp1[i];
	 			 position++;
	 			}
	 	}
	 }

	 public void changeorder(int[] data,int position)
	 {
	 	int temp;
	 	for(int i=0;i<position;i++)
	 	{
	 		temp=data[1];
	 		for(int j=0;j<citynum-1;j++)
	 			data[j]=data[j+1];
	 		data[citynum-1]=temp;
	 	}
	 }

	 //從文本中讀數據
	 public void readdata(int citynum) throws IOException
	 {
	 	String str_temp;

	 	try
		{
	 		RandomAccessFile file=new RandomAccessFile("g:\\javapro\\data.txt","r");
	 		for(int i=0;i<citynum;i++)
	 		{
	 			try
				{
	 				str_temp=file.readLine();
	 				this.city[i][0]=(Double.valueOf(str_temp)).doubleValue();
	 				str_temp=file.readLine();
	 				this.city[i][1]=(Double.valueOf(str_temp)).doubleValue();
	 			}
	 			catch(IOException ex)
				{
	 				ex.printStackTrace();
				}
	 			catch(ArrayIndexOutOfBoundsException ex)
				{
	 				ex.printStackTrace();
				}
	 		}

		}
	 	catch(FileNotFoundException ex)
		{
	 		ex.printStackTrace();
		}
	 }

	 public void initial(int citynum)
	 {
	 	int[] sequence=new int[citynum];
	 	int i,j,nextnum;
	 	try{
	 		readdata(citynum);
	 	}
	 	catch(IOException ex)
		{
			ex.printStackTrace();
		}
	 	Random rr=new Random();
	 	//產生第一代個體
	 	for(i=0;i<popsize;i++)
	 		for(j=0;j<citynum;j++)
	 		{
	 			oldparent1[i][j]=0;
	 		}
	   for(j=0;j<popsize;j++)
	   {
	     //初始化序列
	     for(i=0;i<citynum;i++)
	        sequence[i]=i;
	     int length=citynum-1;
	     //隨機產生的序列
	     for(i=0;i<citynum;i++)
	     {
	     	try
			{
	       	nextnum=rr.nextInt(length+1);

	        oldparent1[j][i]=sequence[nextnum];

	        for(int k=nextnum;k<length;k++)
	        	sequence[k]=sequence[k+1];

	        length--;

			}
	     	catch(IllegalArgumentException ex)
			{
		       	ex.printStackTrace();
			}
	     }
	   }
	 }

	 public double[] calculate_fitness(int[][] parent,int size)
	 {
	   double[] cityfitness=new double[size];//記錄種群的適應度值
	   double sum=0.0;
	   //計算適應度
	   for(int i=0;i<size;i++)
	     {
	   		for(int j=0;j<citynum-1;j++)
	   		{
	         sum+=distance(parent[i][j],parent[i][j+1]);
	   		}
	   		try{
	   			cityfitness[i]=1/sum;
System.out.print("第"+(i+1)+"個 : ");
for(int j=0;j<citynum;j++)
	System.out.print(parent[i][j]+",");
System.out.println("   "+cityfitness[i]);
	   		}
	   		catch(Exception ex)
			{
	   			ex.printStackTrace();
			}
	   		sum=0.0;
	     }
	   return cityfitness;
	 }


	 //x,y為城市的序號,此函數計算x,y之間的距離
	 public double distance(int x,int y)
	 {

	   double result=0.0;
	   result+=(city[x][0]-city[y][0])*(city[x][0]-city[y][0])+(city[x][1]-city[y][1])*(city[x][1]-city[y][1]);
	   return Math.sqrt(result);

	 }


public static void main(String args[]){
	TSP_g test1=new TSP_g();
}

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲午夜免费电影| 7777精品伊人久久久大香线蕉超级流畅 | 亚洲精品自拍动漫在线| av在线一区二区三区| 亚洲精品一二三| 欧美日韩在线不卡| 91行情网站电视在线观看高清版| 国产精品原创巨作av| 一道本成人在线| 国产在线看一区| 久久av中文字幕片| 亚洲欧美综合网| 亚洲欧洲精品一区二区三区不卡| 精品粉嫩aⅴ一区二区三区四区| 欧美日韩免费不卡视频一区二区三区| 91成人在线免费观看| 丁香另类激情小说| 99这里只有久久精品视频| 91天堂素人约啪| 亚洲男人天堂一区| 精品国产自在久精品国产| 国产精品视频一区二区三区不卡| 日韩和的一区二区| 日韩午夜中文字幕| 国内精品伊人久久久久av影院 | 成人动漫av在线| 韩国女主播一区| 久久精品国产久精国产| 久草精品在线观看| 精品在线一区二区三区| 另类小说图片综合网| 久久99最新地址| 国产精品一二一区| jiyouzz国产精品久久| 日韩av电影免费观看高清完整版在线观看| 亚洲国产激情av| 欧美一区二区三区在线| 欧美美女黄视频| 久久欧美中文字幕| 精品国产伦一区二区三区观看体验| 在线播放中文字幕一区| 精品少妇一区二区三区日产乱码 | 欧美最新大片在线看| 欧美精品久久99久久在免费线| 欧美一级理论片| 国产精品不卡在线观看| 三级影片在线观看欧美日韩一区二区 | 91久久精品午夜一区二区| 4hu四虎永久在线影院成人| 国产偷v国产偷v亚洲高清| 亚洲国产一二三| 大胆欧美人体老妇| 宅男在线国产精品| 亚洲视频狠狠干| 麻豆国产欧美一区二区三区| 99久久伊人精品| 欧美刺激脚交jootjob| 一区二区三区免费网站| 国产成人精品网址| 色94色欧美sute亚洲线路一ni| 精品少妇一区二区三区日产乱码| 国产精品亲子乱子伦xxxx裸| 日韩综合在线视频| 欧美午夜免费电影| 久久免费视频色| 天堂va蜜桃一区二区三区漫画版 | 亚洲精品一二三区| 国产在线精品视频| 亚洲最大的成人av| 国产成人小视频| 日韩欧美视频一区| 亚洲图片欧美一区| 91蜜桃视频在线| 久久精品视频免费| 日韩精品一卡二卡三卡四卡无卡| 成人性视频免费网站| 日韩欧美国产一二三区| 日韩精品91亚洲二区在线观看| 91黄色在线观看| 亚洲欧洲精品天堂一级 | 国产一区福利在线| 在线播放/欧美激情| 亚洲大型综合色站| 欧美亚洲图片小说| 亚洲国产一区二区在线播放| 91免费看片在线观看| 久久久99精品久久| 北岛玲一区二区三区四区| 亚洲男人的天堂网| 欧美性生活影院| 日韩制服丝袜av| 久久中文娱乐网| 国内外精品视频| 精品国产髙清在线看国产毛片| 亚洲欧美日韩电影| 在线视频国产一区| 日韩国产精品91| 国产精品久久久久久久裸模| 国产精品三级久久久久三级| 国产欧美精品国产国产专区| 国产日产欧美一区| 国产高清视频一区| 欧美mv和日韩mv国产网站| 精品一区二区在线播放| 日韩一卡二卡三卡国产欧美| 青青草97国产精品免费观看 | 国产成人在线视频播放| 欧美精品一区二区三区在线 | 国产乱码精品1区2区3区| 国产中文字幕精品| 亚洲少妇中出一区| 欧美视频中文一区二区三区在线观看| 日韩精品五月天| 日本一区二区电影| 欧美电视剧免费观看| 99精品视频一区二区| 麻豆免费精品视频| 亚洲图片一区二区| 国产精品水嫩水嫩| 日韩免费观看高清完整版 | 久久 天天综合| 综合久久给合久久狠狠狠97色| 欧美一区二区成人6969| 一本色道a无线码一区v| 国产麻豆9l精品三级站| 国产精品99久久久久久久vr| 日韩二区三区四区| 蜜臀av一区二区在线免费观看| 日韩高清不卡一区| 亚洲永久免费av| 精品国产伦理网| 91麻豆精品91久久久久同性| 91免费观看在线| 91国偷自产一区二区三区成为亚洲经典 | 国产精品电影一区二区三区| www.成人网.com| 一区二区欧美在线观看| 欧美一区二区三区视频免费播放| 国产真实乱偷精品视频免| 中文字幕一区二区三区在线观看| 欧美亚洲综合一区| 久88久久88久久久| 综合婷婷亚洲小说| 日韩一区二区三区三四区视频在线观看| 国产一区二区三区免费| 一区二区不卡在线视频 午夜欧美不卡在| 91精品国产乱| 99久久综合国产精品| 青椒成人免费视频| 亚洲视频综合在线| 日韩三级视频在线看| 91麻豆免费观看| 久99久精品视频免费观看| 亚洲精品videosex极品| 精品成人免费观看| 欧美午夜电影网| 白白色 亚洲乱淫| 麻豆成人久久精品二区三区小说| **性色生活片久久毛片| 精品嫩草影院久久| 色狠狠桃花综合| 粉嫩欧美一区二区三区高清影视| 舔着乳尖日韩一区| 成人欧美一区二区三区白人| 精品久久久久一区二区国产| 在线观看视频一区二区| 国产电影精品久久禁18| 日本中文一区二区三区| 一区二区三区加勒比av| 国产精品欧美久久久久一区二区 | 亚洲国产综合人成综合网站| 欧美激情一区二区三区蜜桃视频 | 午夜精品久久久久久久99樱桃| 国产人伦精品一区二区| 日韩丝袜情趣美女图片| 亚洲精品久久嫩草网站秘色| 久久综合九色综合欧美亚洲| 欧美一区二区三区在线观看视频| 色吊一区二区三区| 波多野洁衣一区| 国产激情91久久精品导航| 久久99久久精品| 欧美a级一区二区| 五月婷婷色综合| 亚洲一区二区黄色| 亚洲免费在线观看| 日韩一区在线免费观看| 日本一区二区三区免费乱视频| 欧美成人在线直播| 欧美一区二区黄| 欧美一区二区三区播放老司机| 欧洲av在线精品| 91久久久免费一区二区| 一本久道久久综合中文字幕| 99久久精品免费观看| 成人精品免费看| 成人avav影音| 99久久国产综合精品麻豆| av在线一区二区| 91丝袜呻吟高潮美腿白嫩在线观看|