数据结构组数相关

1.结构图

Collection                 有序的集合  
 ├------List                 接口  
 │         ├LinkedList 链表               (异步, 线程非安全)  
 │         ├ArrayList    顺序结构动态数组类 (异步, 线程非安全)  
 │         └Vector        向量(同步, 线程安全)  
 │           └Stack    栈 (后进先出)
 └Set                         接口  
Map                           接口  
 ├Hashtable            (同步, 线程安全)  
 ├HashMap             (异步, 线程非安全)  
 └WeakHashMap
2.

List, 有序,接口,允许有相同元素
ArrayList,数组结构,添加删除需要移动它之后的数据,遍历可以用二分,可变大小,允许为null
LinkedList,链表结构,添加删除数据不用移动数据,只能顺序遍历
Vector,
Set,不包含重复元素,最有有一个null元素
HashMap,允许为null,效率高
HashTable,底层是哈希表,不可以存null
因为同步需要花费机器时间,所以Vector和HashTable的执行效率要低于 ArrayList和HashMap
TreeMap,底层是二叉树,线程不同步,可以用于给map集合中的键进行排序
3.如何遍历Collection中的每一个元素

不论Collection的实际类型如何,它都支持一个iterator()的方法,该方法返回一个迭代子,
使用该迭代子即可逐一访问Collection中每一个元素。典型的用法如下:  
Iterator it = collection.iterator(); // 获得一个迭代子     
while(it.hasNext()) {     
    Object obj = it.next(); // 得到下一个元素     
}  

4.对list进行排序

    /** 
         * 对list进行排序 
         * @param list 
         * @param by 排序项 
         * @param d 0、升序;1、降序 
         * @return 
         */  
        public static List<HashMap<String, Object>> orderList(  
                List<HashMap<String, Object>> list, String by, int d) {  
            DefineComparator comparator = new DefineComparator(by, d);  
            Collections.sort(list, comparator);  
            return list;  
        }  
    public class DefineComparator implements Comparator<HashMap<String, Object>> {  
      
        private String order;  
        private int direction;//0、升序,1、降序  
          
        public DefineComparator(String string, int dir) {  
            super();  
            // TODO Auto-generated constructor stub  
            order = string;  
            direction = dir;  
        }  
      
        @Override  
        public int compare(HashMap<String, Object> lhs, HashMap<String, Object> rhs) {  
            // TODO Auto-generated method stub  
            double one = Double.valueOf(lhs.get(order).toString());  
            double two = Double.valueOf(rhs.get(order).toString());  
            if(direction == 0){  
                if(one > two) return 1;  
                if(one < two) return -1;  
            }else if(direction==1){  
                if(one > two) return -1;  
                if(one < two) return 1;  
            }  
            return 0;  
        }  
          
        public void setDir(int dir){  
            direction = dir;  
        }  
    }  

5.keySet和entrySet

// 第一种取出方式keySet
        Set<Student> keySet = hm.keySet();
        Iterator<Student> iterator = keySet.iterator();
        while (iterator.hasNext()) {
            Student student = iterator.next();
            String addr = hm.get(student);
            System.out.println(student + ":" + addr);
        }

//第二种取出方式 entrySet
        Set<Entry<Student, String>> entrySet = hm.entrySet();
        Iterator<Entry<Student, String>> iterator2 = entrySet.iterator();
        while (iterator2.hasNext()) {
            Entry<Student, String> next = iterator2.next();
            System.out.println(next.getKey()+":"+next.getValue());
        }
文章 http://blog.csdn.net/qq_26787115/article/details/51762397     Map,keySet,entrySet 






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值