本文实例讲述了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程序设计有所帮助。
已知字母序列【d, g, e, c, f, b, o, a】,请实现一个函数针对输入的一组字符串 input[] = {“bed”, “dog”, “dear”, “eye”},按照字母顺序排序并打印,结果应为:dear, dog, eye, bed。 说明 本问题在网上比较常见,但这里尝试用另外一个思路,并且用python来写,与众多用c++的有所不同,且似乎短小了不少。自己感觉比网上参考到的更
问题内容: 我有一个包含人名的字符串arraylist 。我想按字母顺序对arraylist进行排序。 我试图以上述方式对列表进行排序。但是它将排序后的数组显示为: 但我不想使其区分大小写。我想要的结果是: 问题答案: 自定义应该有帮助 或者,如果你使用的是Java 8:
问题内容: 我是Java的新手,正在尝试按字母顺序排列术语的arrayList。(一个术语定义为一个字符和一个整数)(例如 我的代码如下: 为什么这不起作用?以及我该如何完成呢?我的arrayList称为术语,填充有Term类型 问题答案: 您在这行代码中遇到的问题。您的课程不是So 的类型,这两个对象将基于哪个属性或条件方法? 您必须使您的类为Comparable类型。和,根据您的需要覆盖该方法
我使用的是mySQL和排序规则。 我尝试了以下查询: 结果是: 是否在上面的排序规则中设置了这种排序类型(小写字母按降序排列)? 另外,如果我运行以下查询: 结果是: 再次以升序排列,小字母排在第一位。我不明白。请给我解释一下。 如何更改数据库排序规则?
问题内容: 我有此代码,但仅适用于小写字母。我希望它在不考虑大写字母的情况下对列表进行排序。 问题答案: 这是最佳方法的简单Java示例:
我必须创建一个方法,根据电子邮件按字母顺序排序对象的ArrayList,然后打印排序后的数组。我对它排序有困难的部分。我已经研究过它,并尝试使用,但这对我不起作用。我需要一种叫做比较器的东西,但不知道它是如何工作的。我必须使用这些,或者像气泡排序或插入排序之类的东西可以用于这种事情吗? 这是我目前掌握的代码: