JAVA小例子解析算法效率

今天本来想熟悉一下J2SE的内容,不想在编写过程中突然考虑到一个问题,JAVA算法的效率,大家先看我自己写的一个小例子:

public class NumSort {
 public static void mian (String args[]) {
  int a[] = new int[args.length];
  for (int i=0;i<args.length;i++) {
   a[i] = Integer.parseInt(args[i]);
  }
  print(a);
  selectionSort(a);
  print(a);
 }
 
 private static void selectionSort(int a[]) {
  for (int i=0;i<=a.length;i++) {
   for (int j=i+1;j<a.length;j++) {
    if (a[j]<a[i]) {
     int temp = a[i];
     a[i] = a[j];
     a[j] = temp;
    }
   }
  }
 }
 
 private static void print(int a[]) {
  for (int i=0;i<=a.length;i++) {
   System.out.print(a[i] + " ");
  }
  System.out.println();
 }
}

这个小程序实现的功能是从键盘输入一串字符,将他们转换成int类型的数,并实现选择排序,将结果输出,那么我们按上面的算法来看这么个序列:1 4 6 7 3 5 2 9 8 我们看4,当4与3比较的时候会有一次交换,而当3与2再比较的时候还有一次交换,我们说这次交换是没有必要的,我们理想的做法是每一次遍历都能只交换一次而找出此次遍历里最小的数,我们的方法是再设置一个计数j,让j记住我们要交换的位置, 即我们找到3之后,拿3和后面的数再进行比较,如果没有比3小的就交换,如果发现比3小的,如此处的2,则j移动到2的位置,最后再交换,让我们看下面的小程序:

public class GoodNumSort {
 public static void mian (String args[]) {
  int a[] = new int[args.length];
  for (int i=0;i<args.length;i++) {
   a[i] = Integer.parseInt(args[i]);
  }
  print(a);
  selectionSort(a);
  print(a);
 }
 
 private static void selectionSort(int a[]) {
  int k,temp;
  for (int i=0;i<=a.length;i++) {
   k = i;
   for (int j=k+1;j<a.length;j++) {
    if (a[j]<a[i]) {
     temp = a[k];
     k = j;
    }
   }
   if (k !=i) {
    temp = a[i];
    a[i] = a[k];
    a[k] = temp;
   }
  }
 }
 
 private static void print(int a[]) {
  for (int i=0;i<=a.length;i++) {
   System.out.print(a[i] + " ");
  }
  System.out.println();
 }
}

当然,JAVA本身为我们封装了很好的算法,一般不需要我们去专门研究算法,只要调用Sort就好了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值