龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > JAVA开发 >

java版本的冒泡算法

时间:2009-12-23 15:42来源:未知 作者:admin 点击:
分享到:
/** 文件名:MaoPao.Java 描述: java版本的冒泡算法 作者:慈勤强 Email:cQQ1978@Gmail.com **/ class MaoPao { public static void test1() //最普通的冒泡算法,需要比较(n-1)*(n-1)次 { int[] iArray={10,5,2,3,321,

  /**
  文件名:MaoPao.Java
  描述: java版本的冒泡算法
  作者:慈勤强
  Email:cQQ1978@Gmail.com
  **/
  
  class MaoPao
  {
  
   public static void test1() //最普通的冒泡算法,需要比较(n-1)*(n-1)次
   {
   int[] iArray={10,5,2,3,321,76,3221,98,86,39};
   int k=0;
   int icount=0;
   for(int j=0;j<iArray.length-1;j++)
   {
   for(int i=0;i<iArray.length-1;i++)
   {
   if(iArray[i]>iArray[i+1])
   {
   k=iArray[i];
   iArray[i]=iArray[i+1];
   iArray[i+1]=k;
   }
   icount++;
   }
   }
  
   System.out.println("共做比较次数: "+icount);
   for(int i=0;i<iArray.length;i++)
   {
   System.out.print(" "+iArray[i]);
   }
  
   }
   public static void test2() //稍微作了一下改进,加入一个布尔变量,当顺序已经排好后,就不用做额外的比较了
   {
   int[] iArray={10,5,2,3,321,76,3221,98,86,39};
   int k=0;
   int icount=0;
   boolean b=false;
   for(int j=0;j<iArray.length-1;j++)
   {
   b=false;
   for(int i=0;i<iArray.length-1;i++)
   {
   if(iArray[i]>iArray[i+1])
   {
   k=iArray[i];
   iArray[i]=iArray[i+1];
   iArray[i+1]=k;
   b=true;
   }
   icount++;
   }
   if(!b) break;
   }
  
   System.out.println(" 共做比较次数: "+icount);
   for(int i=0;i<iArray.length;i++)
   {
   System.out.print(" "+iArray[i]);
   }
  
   }
   public static void main(String[] args)
   {
   test1();
   test2();
   }
  }
  
精彩图集

赞助商链接