你是想自己写排序算法呢还是直接用Java提供的API呢?如果想用JAVA里面的API那就推荐你用Arrays里面的sort方法,你可以为这种A--13,D--6,S--9,F--15,T--13创建一个实现Comparable接口的对象,实现里面的compareTo方法来定义你的字母所对应的大小。前者你就好好想想用什么算法实现吧,后者我写了一个实例:
import java.util.Arrays;
public class TestCompare implements Comparable
private final char c;
private final int i;
/**
* @return the string
*/
public char getC() {
return c;
}
/**
* @return the i
*/
public int getI() {
return i;
}
public TestCompare(char c, int i) {
this.i = i;
this.c = c;
}
public int compareTo(TestCompare o) {
// TODO Auto-generated method stub
if (o == null) {
// 表示当前实例的位置在o之后
return 1;
} else {
// 先比较数字
if (this.getI() > o.getI()) {
// 表示当前实例的位置在o之前
return -1;
} else if (this.getI() == o.getI()) {
// 数字相等开始比较字母
// char型强转成int行,A到Z各代表多少值应该都知道吧
if (this.getC() < o.getI()) {
// 表示当前实例的位置在o之前
return -1;
} else if (this.getC() == o.getI()) {
// 表示当前实例的位置在o相等
return 0;
} else {
// 表示当前实例的位置在o之后
return 1;
}
} else {
// 表示当前实例的位置在o之后
return 1;
}
}
}
@Override
public String toString() {
return new Character(this.getC()).toString();
};
public static void main(String[] args) {
TestCompare[] compare = new TestCompare[] { new TestCompare('A', 13),
new TestCompare('D', 6), new TestCompare('S', 9),
new TestCompare('F', 15), new TestCompare('T', 13) };
Arrays.sort(compare);
for (TestCompare compare2 : compare) {
System.out.print(compare2);
}
}
}
使用冒泡排序撒,我也忘记了具体的,自己百度哦