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;
相关文档:
异常列表:
1. java.lang.nullpointerexception
2. Java.lang.classnotfoundexception
3. Java.lang.arithmeticexception
4. Java.lang.arrayindexoutofboundsexception
5. Java.lang.illegalargumentexception
6. java.lang.illegalaccessexception
1. java.lang.nullpoi ......
线性表,链表,集合,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的类来实现基本的数据结构。这些类均在java.util包中。
Collection
├List
│├LinkedList
│├ArrayList
│└Vector
│ └Stack
└Set
Map
├Hashtable
├HashMap
└WeakHashMap
主要分为两个分支:
Collectio ......
注:wait notify 都是Object的方法
同步(阻塞) :是一种防止对共享资源访问导致的数据不一致的一种模式。
详细请参看操作系统。
在Java中,由于对多线程的支持,对同步的控制主要通过以下几个方法,synchronized,和wait(),notify()和notifyAll(),下面进行一一的讲解:
A关键字synchronized
每个java对 ......