A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 官珺伟 高级黑马   /  2014-4-23 08:45  /  935 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 官珺伟 于 2014-4-23 21:47 编辑

Collections.reverseOrder();//逆向反转排序。
Collections.shuffle(list);//随机对list中的元素进行位置的置换。
Collections.reverseOrder() 括号里面要加list 吗?
改为Collections.reverseOrder(list);行吗?

reverse(List<?> list)
          反转指定列表中元素的顺序  ,直接上reverse(list); 行吗?




点评

建议好好再看看视频  发表于 2014-4-25 21:31

2 个回复

倒序浏览
本帖最后由 孙旌棋 于 2014-4-23 16:43 编辑

第一个问题: 括号里肯定是不能加list的, Collections.reverseOrder()是返回一个比较器,它强行逆转实现了Comparable 接口的对象 collection 的自然顺序, 比较器是什么我就不多跟你讲了

第二个问题: 反转指定列表中元素的顺序  ,直接上reverse(list); 行吗?答案是必须可以的

同学, 这里给你写了一个小例子, 运行一下就可以看到效果的哦
同时,我还建议你, 遇到似是而非的一定要亲自写代码测试一下

  1. import java.util.ArrayList;
  2. import java.util.Collections;
  3. import java.util.Iterator;
  4. import java.util.List;
  5. import java.util.TreeSet;

  6. public class SunJingQi {

  7.         public static void main(String[] args) {

  8.                 List<String> list = new ArrayList<String>();
  9.                 list.add("Sun");
  10.                 list.add("Jing");
  11.                 list.add("Qi");

  12.                 // 原来的顺序输出
  13.                 for (Iterator<String> it = list.iterator(); it.hasNext();) {
  14.                         System.out.println(it.next());
  15.                 }

  16.                 Collections.reverse(list);// 反转指定列表中元素的顺序

  17.                 // 反转后的顺序输出
  18.                 for (Iterator<String> it = list.iterator(); it.hasNext();) {
  19.                         System.out.println(it.next());
  20.                 }

  21.                 TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder());
  22.                 ts.add("Sun");
  23.                 ts.add("Jing");
  24.                 ts.add("Qi");

  25.                 /*
  26.                  * 同学, 这里最后的结果是 Sun Qi Jing 是不是很疑惑呢?
  27.                  * 原因很简单, TreeSet有个默认顺序的就是按照字母的顺序排序
  28.                  * 那么原来的顺序就是 Jing Qi Sun
  29.                  * Collections.reverseOrder()返回一个比较器,它强行逆转实现了Comparable接口的对象collection 的自然顺序
  30.                  * 就是把原来的顺序反过来, 那答案就是 Sun Qi Jing了哦
  31.                  * 同学看到这里你明白了吗?
  32.                  */

  33.                 for (Iterator<String> it = ts.iterator(); it.hasNext();) {
  34.                         System.out.println(it.next());
  35.                 }

  36.         }
  37. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
枫儿 + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马