Java 排序算法

java有自带了对两类数据结构的排序方法,一类是数组的排序,使用的是Arrays类的sort方法;另一类是队列的排序,使用的是Collections类的sort方法。sort方法中的参数就有对元素进行排序的算法类Comparator,可由开发者自定义算法比较两个元素的大小。其中有关java队列的介绍参见《 Android开发笔记(二十六)Java的容器类 》,下面是对数组和队列进行排序的代码示例:
[java]  view plain  copy
  1. public static void main(String[] arg) {  
  2.       
  3.     String[] strArray = {"abc""aaa""abb""tgy""ctr"};  
  4.     System.out.println("before sort");  
  5.     for (int i=0; i<strArray.length; i++) {  
  6.         System.out.println("strArray["+i+"]="+strArray[i]);  
  7.     }  
  8.     Arrays.sort(strArray, new Comparator<String>() {  
  9.         @Override  
  10.         public int compare(String o1, String o2) {  
  11.             return o1.compareTo(o2);  
  12.         }  
  13.     });  
  14.     System.out.println("after sort");  
  15.     for (int i=0; i<strArray.length; i++) {  
  16.         System.out.println("strArray["+i+"]="+strArray[i]);  
  17.     }  
  18.       
  19.     ArrayList<Integer> intList = new ArrayList<Integer>();  
  20.     intList.add(10);  
  21.     intList.add(4);  
  22.     intList.add(7);  
  23.     intList.add(1);  
  24.     intList.add(3);  
  25.     System.out.println("before sort");  
  26.     for (int i=0; i<intList.size(); i++) {  
  27.         System.out.println("intList.get("+i+")="+intList.get(i));  
  28.     }  
  29.     Collections.sort(intList, new Comparator<Integer>() {  
  30.         @Override  
  31.         public int compare(Integer o1, Integer o2) {  
  32.             return (o1>o2)?1:-1;  
  33.         }  
  34.     });  
  35.     System.out.println("after sort");  
  36.     for (int i=0; i<intList.size(); i++) {  
  37.         System.out.println("intList.get("+i+")="+intList.get(i));  
  38.     }  
  39.       
  40. }  

下面是示例代码的运行结果:
[java]  view plain  copy
  1. before sort  
  2. strArray[0]=abc  
  3. strArray[1]=aaa  
  4. strArray[2]=abb  
  5. strArray[3]=tgy  
  6. strArray[4]=ctr  
  7. after sort  
  8. strArray[0]=aaa  
  9. strArray[1]=abb  
  10. strArray[2]=abc  
  11. strArray[3]=ctr  
  12. strArray[4]=tgy  
  13. before sort  
  14. intList.get(0)=10  
  15. intList.get(1)=4  
  16. intList.get(2)=7  
  17. intList.get(3)=1  
  18. intList.get(4)=3  
  19. after sort  
  20. intList.get(0)=1  
  21. intList.get(1)=3  
  22. intList.get(2)=4  
  23. intList.get(3)=7  
  24. intList.get(4)=10  


与排序算法相类似的,还有图片缓存用到的排队算法(又称淘汰算法、置换算法),例如:先进先出FIFO、后进先出LIFO、最近最久未使用LRU、最不经常使用LFU等等。有关图片缓存的介绍参见《 Android开发笔记(七十七)图片缓存算法 》。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值