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

📄 fac5_9.java

📁 java 算法设计与分析的好资料.由王晓东先生主编.
💻 JAVA
字号:
//本程序取自王晓东编著“算法分析与设计”第 174 页,例
//货郎担问题的回溯解法
//
 
    class Bttsp
      {
        static int n;          //图G的顶点个数
        static int []x;        //当前解
        static int [] bestx;  //当前最优解
        static float bestc;   //当前最优值
        static float cc;      //当前费用
        static float [][]a;   //图G的临界矩阵

      public static float tsp(int[] v)
        {//置x为单位排列
          x=new int[n+1];
          for(int i=1;i<=n;i++)
            x[i]=i;
          bestc=Float.MAX_VALUE;
          bestx=v;
          cc=0;
          //搜索x[2:n]的全排列
          backtrack(2);
          return bestc;
        }

      private static void backtrack(int i)
        {
          if(i==n)
            {
              if(a[x[n-1]][x[n]]<Float.MAX_VALUE && a[x[n]][1]<Float.MAX_VALUE &&
                (bestc==Float.MAX_VALUE||cc+a[x[n-1]][x[n]]+a[x[n]][1]<bestc))
              {
                for(int j=1;j<=n;j++)
                  bestx[j]=x[j];
                bestc=cc+a[x[n-1]][x[n]]+a[x[n]][1];    
              }
            }
          else
            {
            for(int j=i;j<=n;j++)
             {//
              if(a[x[i-1]][j]<Float.MAX_VALUE &&
                (bestc==Float.MAX_VALUE||cc+a[x[i-1]][x[j]]<bestc));
              {//
               swap(x,i,j);
               cc+=a[x[i-1]][x[i]];
               backtrack(i+1);
               cc-=a[x[i-1]][x[i]];
               swap(x,i,j);
              }
            }
           }
       }
       static void swap(int[] a,int i1,int j1)
        {
          int temp;   
          temp=a[i1];
          a[i1]=a[j1];
          a[j1]=temp;
        }      
       }//

   public class Fac5_9{
  
      public static void main(String args[])
  {
     Bttsp abc=new Bttsp();
     int n1=4;   
     int v1[]=new int[n1+1];
     float a1[][]=new float [n1+1][n1+1];
      a1[1][1]=0.0f; a1[1][2]=30.0f; a1[1][3]=6.0f;  a1[1][4]=4.0f; 
      a1[2][1]=30.f; a1[2][2]=0.0f;  a1[2][3]=5.0f;  a1[2][4]=10.0f; 
      a1[3][1]=6.0f; a1[3][2]=5.0f;  a1[3][3]=0.0f;  a1[3][4]=20.0f; 
      a1[4][1]=4.0f; a1[4][2]=10.0f; a1[4][3]=20.0f; a1[4][4]=0.0f;
      for(int k=0;k<=n1;k++)      
        v1[k]=0;
     
     abc.a=a1;         
     abc.n=n1;
         
     System.out.println("货郎担问题的最优解   " + abc.tsp(v1));
     for(int k=1;k<=n1;k++)
     System.out.print("  "+abc.bestx[k]);
     System.out.println();
  }
}

⌨️ 快捷键说明

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