本文實例講述了Java實現按照大小寫字母順序排序的方法。分享給大家供大家參考,具體如下:
這里排序需要得到的結果按字母順序。如:a-----z...
import java.util.*; /** * 大小寫字母的排序 * @author Administrator * */ public class z { //上邊是按大寫在后的進行排序 static Map<Character,Float> map=new HashMap<Character,Float>();//hashMap允許null值 //按大寫在前的進行排序 static Map<Character,Float> map1=new HashMap<Character,Float>();//hashMap允許null值 // static{ Character ch; for (ch = 65; ch < 91; ch++) {//大寫65.0;66.0;67.0;68.0 map.put(ch,(float)ch.hashCode()); } for (ch = 97; ch < 123; ch++) {//小寫64.5;65.5 map.put(ch,(float)ch.hashCode()-(float)32-0.5f); } for (ch= 65; ch < 91; ch++) {//大寫65.0;66.0;67.0;68.0 map.put(ch, (float)ch.hashCode()); } for (ch = 97; ch < 123; ch++) {//小寫64.5;65.5 map.put(ch, (float)ch.hashCode()-(float)32+0.5f); } } /** * @first 大寫在后的數組值在map中找 value的值 * @second 通過Collections的排序方法得到遞增數List * @third 反操作map得到char值 * @param ar要排序的數組 */ public List addList(char[] ar){ List list =new java.util.ArrayList(); for (int i = 0; i < ar.length; i++) { list.add(map.get(ar[i])); } List lis=new ArrayList(); Collections.sort(list); Iterator it=list.iterator(); while(it.hasNext()){ String str=it.next().toString(); if(str.endsWith(".0")){ lis.add((char)Float.parseFloat(str)); }else{ lis.add((char)(Float.parseFloat(str)+0.5+32)); } } return lis; } /** * 大寫在前的數組值在map中找value的值 * @param ar * @return */ public List addList1(char[] ar){ List list=new java.util.ArrayList(); for (int i = 0; i < ar.length; i++) { list.add(map.get(ar[i])); } List lis=new ArrayList(); Iterator it=list.iterator(); while(it.hasNext()){ String str=it.next().toString(); if(str.endsWith(".0")){ lis.add((char)Float.parseFloat(str)); }else{ lis.add((char)(Float.parseFloat(str)+0.5-32)); } } return lis; } public static void main(String []args){ System.out.println("億速云測試結果:"); char ch [] ={'A','a','b','f','m','K'}; List list=new z().addList(ch); Iterator it=list.iterator(); while(it.hasNext()){ System.out.println(it.next()+","); } } }
運行結果:
更多關于java算法相關內容感興趣的讀者可查看本站專題:《Java數據結構與算法教程》、《Java操作DOM節點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。