package com.itic.regulus.wf.task.controller;
public class testController {
public static void main(String[] args) {
System.out.println(sort(getString()));
}
static String a="When not studying Java programming. Tom likes to play Xbox.";
public static String getString(){
StringBuffer str = new StringBuffer();
for(int i=0;i<a.length();i++){
if(a.charAt(i)>=97 && a.charAt(i)<=122 )
str.append(a.charAt(i));
else if(a.charAt(i)>=65 && a.charAt(i)<=90)
str.append((char)(a.charAt(i)+32));
}
return str.toString();
}
public static String sort(String str){
char[] c = new char[str.length()];
for(int i=0;i<str.length();i++){
c[i]=str.charAt(i);
}
char[] d=bubbleSort(c, c.length);
StringBuffer sb = new StringBuffer();
for(int j=0;j<d.length;j++){
sb.append(d[j]);
}
return sb.toString();
}
public static char[] bubbleSort(char[] c,int n){
int i,j,flag;
for (i = 1; i<=n-1; i++) {
flag=0;
for (j = n-1; j >=i ; j--)
if(((Comparable)c[j]).compareTo((Comparable)c[j-1])<0){
char x = c[j];c[j]=c[j-1];c[j-1]=x;
flag=1;
}
if(flag==0) break;
}
return c;
}
}
aaaabdeeggghiiijkllmmmnnnnooooopprrssttttuvwxxyy
注释:字符常量是用单引号括起的一个字符 且字符常量在内存中存储的是该字符在Unicode字符集中的排序位置,即整数
eg:char x='a'
内存x中存储的是字符a在Unicode字符集中的排序位置97 因此允许将上面的语句写成char x=97;
a :97 z:122
A: 65 Z:90