黑马程序员技术交流社区

标题: 请问汉字的字典顺序怎么实现? [打印本页]

作者: 卜弦    时间: 2013-11-17 16:32
标题: 请问汉字的字典顺序怎么实现?
本帖最后由 卜弦 于 2013-11-18 12:32 编辑

要想实现汉字的字典顺序,使用Collections中的sort方法可以吗?
请问自然顺序和字典顺序有什么区别?
我尝试使用sort方法对一组汉字词排序,得到的不是想要的结果啊!!
比如输入:
阿姨
曹操
父亲
爸爸
哥哥
爷爷
奶奶
end
排序后 输出却是:[哥哥, 奶奶, 曹操, 父亲, 爷爷, 爸爸, 阿姨]
好像不对劲。。。。。谁知道怎么排吗?
作者: 陈文杰    时间: 2013-11-17 18:22
import java.util.*;
import java.text.*;

        public class SortByChinese {
        //测试
            public static void main(String[] args) {

                String[] a1 = {"张三","李四","王五","猴六","刘七"};
                getSortOfChinese(a1);
                for (int i = 0; i < a1.length; i++) {
                    System.out.println(a1[i]);
                }
            }
        /**
         *
         * @param a String[]
         * @return String[]
         */
            public static String[] getSortOfChinese(String[] a) {
                // Collator 类是用来执行区分语言环境这里使用CHINA
                    Collator cmp = Collator.getInstance(java.util.Locale.CHINA);

                // JDK自带对数组进行排序。
                Arrays.sort(a);
                return a;
            }
        }
刘七
张三
李四
猴六
王五



作者: 卜弦    时间: 2013-11-17 19:05
陈文杰 发表于 2013-11-17 18:22
import java.util.*;
import java.text.*;

这是字典排序吗?
张三不是应该在最后吗?
作者: 陈文杰    时间: 2013-11-17 22:09
卜弦 发表于 2013-11-17 19:05
这是字典排序吗?
张三不是应该在最后吗?

额,是有点不对额。如下面:
Test.java文件
import java.util.*;
class Test
{
        public static void main(String[] args)
        {
                ArrayList<String> al=new ArrayList<String>();
                al.add("张三");
                al.add("李四");
                al.add("王五");
                al.add("猴六");
                al.add("刘七");
                Collections.sort(al,new SortComparator());               
                for(String  name  :  al)
                {
                        System.out.println(name);
                }               
        }
}


SortComparator.java文件

import java.util.Comparator;

class SortComparator implements Comparator<Object>
{
        public int compare(Object o1,Object o2)
        {
                try
                {
                        byte[] buf1 = ((String) o1).getBytes("GB2312");
                        byte[] buf2 = ((String) o2).getBytes("GB2312");
                        int size = Math.min(buf1.length, buf2.length);
                        for (int i = 0; i < size; i++)
                        {
                                if (buf1 < buf2)
                                        return -1;
                                else if (buf1 > buf2)
                                return 1;
                        }
                        return buf1.length - buf2.length;
                        }
                        catch(Exception ex)
                        {
                                return 0;
                        }
        }
}

结果:猴六
李四
刘七
王五
张三

作者: 陈文杰    时间: 2013-11-17 22:10
想要了解更多:http://j2ee-yohn.iteye.com/blog/272006
作者: 陈文杰    时间: 2013-11-17 22:31
上面字体错误

  1. class SortComparator implements Comparator<Object>
  2. {
  3.         public int compare(Object o1,Object o2)
  4.         {
  5.                 try
  6.                 {
  7.                         byte[] buf1 = ((String) o1).getBytes("GB2312");
  8.                         byte[] buf2 = ((String) o2).getBytes("GB2312");
  9.                         int size = Math.min(buf1.length, buf2.length);
  10.                         for (int i = 0; i < size; i++)
  11.                         {
  12.                                 if (buf1[i] < buf2[i])
  13.                                         return -1;
  14.                                 else if (buf1[i] > buf2[i])
  15.                                 return 1;
  16.                         }
  17.                         return buf1.length - buf2.length;
  18.                         }
  19.                         catch(Exception ex)
  20.                         {
  21.                                 return 0;
  22.                         }
  23.         }
  24. }
复制代码

作者: 陈文杰    时间: 2013-11-17 23:15
求技术分呐。学长,同学。
作者: 卜弦    时间: 2013-11-18 12:31

不错!谢啦




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2