源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Java实现按照大小写字母顺序排序的方法

  • 时间:2020-02-02 15:38 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Java实现按照大小写字母顺序排序的方法
本文实例讲述了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()+",");
  }
 }
}

运行结果: [img]http://files.jb51.net/file_images/article/201712/2017121591657987.jpg?2017111591952[/img] 更多关于java算法相关内容感兴趣的读者可查看本站专题:《[url=http://www.1sucai.cn/Special/632.htm]Java数据结构与算法教程[/url]》、《[url=http://www.1sucai.cn/Special/830.htm]Java操作DOM节点技巧总结[/url]》、《[url=http://www.1sucai.cn/Special/687.htm]Java文件与目录操作技巧汇总[/url]》和《[url=http://www.1sucai.cn/Special/682.htm]Java缓存操作技巧汇总[/url]》 希望本文所述对大家java程序设计有所帮助。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部