本文实例讲述了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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。