Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
java版本的冒泡算法

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

java版本的冒泡算法



/**
文件名:MaoPao.java
描述: java版本的冒泡算法
作者:慈勤强
Email:
[email protected]
**/

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("\r\n\r\n共做比较次数: "+icount);
  for(int i=0;i<iArray.length;i++)
  {
   System.out.print(" "+iArray[i]);
  }
 
 }
 public static void main(String[] args)
 {
  test1();
  test2();
 }
}




相关文章

相关软件