当前位置: 首页 > news >正文

网站定制开发流程和功能自动交换友情链接

网站定制开发流程和功能,自动交换友情链接,wordpress 红酒,南山区做网站公司Java中的数据结构 Java语言在设计之初有一个非常重要的理念便是:write once,run anywhere!所以Java中的数据结构是已经被设计者封装好的了,我们只需要实例化出想使用的对象,便可以操作相应的数据结构了,本篇…

Java中的数据结构

       Java语言在设计之初有一个非常重要的理念便是:write once,run anywhere!所以Java中的数据结构是已经被设计者封装好的了,我们只需要实例化出想使用的对象,便可以操作相应的数据结构了,本篇文章中我会向大家简单介绍一下什么是数据结构,以及对Java中常用的数据结构做简单介绍,在以后的文章中我会结合Java源码对Java中的每一个数据结构进行详细介绍并亲手实现,欢迎大家在评论区交流想法和意见啊。

目录

Java中的数据结构

1.什么是数据结构?

2.java中的数据结构(集合类)

3.java中的泛型

4.Java中Comparable和Comparator接口

5.时间和空间复杂度


1.什么是数据结构?

       数据结构是计算机中存储,组织数据的方式。我们现在学习的数据结构都是历史中总结出来的典型的优良的程序结构,在开发中多利用这些数据结构能显著提高你的代码质量。 

       我们需要学习的数据结构有:线性表,链表,堆,栈,队列,哈希表,二叉树,图等。

2.java中的数据结构(集合类)

 上图中表示了Java中的集合框架,大致可以分为list,set,map三种体系:

  1. Iterable:这是Java中负责迭代遍历的一个接口,内部包含了遍历的一些方法。
  2. Collection:一个接口,包含了大部分容器常用的一些方法
  3. List:一个接口,规范了ArrayList和Linkedlist中要实现的方法  
  4. ArrayList:Java中最常用的集合类,底层为动态类型顺序表。
  5. LinkedList :实现了list接口,底层为双向链表。
  6. Stack:底层是栈,栈是一种特殊的顺序表。
  7. Queue:底层是队列,队列是一种特殊的顺序表。
  8. Deque:一个接口,实现了双向队列的方法。
  9. PriorityQueue:堆(又称为优先级队列),实现类,内部可按照大小堆的模式实现排序。
  10. Set:一个接口,不能储存相同元素。
  11. HashSet:底层为哈希桶,查询的时间复杂度是O(1);
  12. TreeSet:底层是红黑树,查询的时间复杂度是O(log2 N),内部数据有序。
  13.     Map:一个接口,里面存储的是K-V模型的键值对
  14. HashMap:底层为哈希桶,查询时间复杂度为O(1)
  15. TreeMap:底层为红黑树,查询的时间复杂度为O(log2 N),内部数据有序。

3.java中的泛型

这个我准备在JavaSE专栏专门写一篇进行讲解,明天我会挂上链接。

4.Java中Comparable和Comparator接口

联系:

两者都是接口,都是Java中用来进行类型排序的。两者的排序方法均是通过相减返回一个int值,

返回正数,零和负数分别代表大于,等于和小于。

区别:

  1. 字面区别:comparable是比较的意思,表示自身具备着某种能力。而comparator是比较器的意思,表示自身是比较的参与者。
  2. 用法不同:comparable是由重写compareTo方法实现排序的,如果自定义类没有实现该接口是不能通过Collections.sort方法和Arrays.sort方法进行排序的。而comparator是由重写compare方法实现排序的,可以通过创建自定义比较器或者匿名内部类快捷创建比较器来实现比较。。
  3. 使用场景不同:Comparable必须由自定义类内部实现排序方法,而Comparator无需修改原有类。Comparable可以看做对内进行排序接口,而comparator是对外进行排序的接口。

5.时间和空间复杂度

学习时间和空间复杂度的作用主要是帮助我们去分析一个数据结构或算法的优缺点,从这两方面来衡量一个算法的好坏。

算法效率分析分为两种:第一种是时间效率,第二种是空间效率 时间效率被称为时间复杂度,而空间效率被称作 空间复杂度 时间复杂度主要衡量的是一个算法的运行速度,而空间复杂度主要衡量一个算法所需要的额外空间。
  1. 时间复杂度:我们用O()表示
    // 计算func2的时间复杂度?
    void func2(int N) {
    int count = 0;
    for (int k = 0; k < 2 * N ; k++) {
    count++;
    }
    int M = 10;
    while ((M--) > 0) {
    count++;
    }
    System.out.println(count);
    }
    在实际中一般情况关注的是算法的最坏运行情况上述为2N+10次,所以上述代码中时间复杂度为O(N),一般都是粗略表示。
  2. 空间复杂度:同样也是大O渐进表示法来表示
    // 计算fibonacci的空间复杂度?
    int[] fibonacci(int n) {
    long[] fibArray = new long[n + 1];
    fibArray[0] = 0;
    fibArray[1] = 1;
    for (int i = 2; i <= n ; i++) {
    fibArray[i] = fibArray[i - 1] + fibArray [i - 2];
    }
    return fibArray;
    }

    上述代码中动态开辟了N个空间,空间复杂度为O(N)。

http://www.khdw.cn/news/46439.html

相关文章:

  • 无锡建设银行官网招聘网站千锋教育可靠吗
  • vps做网站怎么加速全网营销推广方案
  • 网页设计与制作教程pdf下载seo搜狗排名点击
  • 深圳网站制作公司嘉兴百度导航下载2022最新版官网
  • 网站做系统叫什么百度代理查询
  • 百度推广计划seo上海网站推广
  • asp企业网站源码优化网站找哪家
  • b2b买方为主导的网站有哪些国内免费发布产品的平台
  • 建站seo赚钱2021年中国关键词
  • 广州做贷款有什么网站郑州网站推广排名公司
  • 邢台地区网站建设无货源网店怎么开
  • 物流网站建设计划书查网站排名
  • 2023年石家庄疫情最新政策企业seo优化
  • 打电话说帮忙做网站软文新闻发布网站
  • 做一个自己的网站要多少钱企业推广网络营销外包服务
  • 天津建设工程信息网评标专家怎么查询评审项目郑州seo外包v1
  • 武汉做网站制作网络营销意思
  • 数据上传网站百度人工服务24小时热线电话
  • wordpress需要认证济南seo的排名优化
  • wordpress菜单跳转到目录重庆网站优化
  • 国内外做的比较好的家装网站营销型网站模板
  • 网上公司注册深圳谷歌seo推广
  • 批发零售网站建设厦门seo代运营
  • 中国正规的加盟网站长沙seo外包
  • html网站免费下载seo文章生成器
  • 网站注册地查询网盘资源共享群吧
  • 购物网站推广排名app
  • 顶级网站建设世界杯积分榜排名
  • 广州制作网站平台福建省人民政府
  • 专业做营销网站建设亚马逊免费的关键词工具