javaSE基础(三)
泛型类:像ArrayList这样的特殊类,他们允许通过类型参数来指明使用的数据类型。
报装类:一种用于将基本类型的数据“封装”成对象的类。
装箱:将 基本类型的数据自动转换为对应类型的报装类对象(如,int会被装箱为Integer)的过程。
拆箱:将报装类对象自动转换为对应的基本类型数据(如,Integer会被拆箱为int)的过程。
比较函数:一种用于判断给定两个值之间关系(大于、小于或等于)的函数。
自然排序:某种类型数值的顺序关系,它由该类型上定义的比较函数决定。
数据结构:用于存储和管理数据的实体被称为数据结构。
集合:集合(collection)对象中可以保存一组其它类型的对象数据,这些内部对象称为集合中的元素。
线性表(List):一组有序元素的集合,可以使用整数索引或顺序来访问其中的元素。
栈(Stack):一种有序的元素集合,支持添加和删除位于“顶端”的元素,实现后进先出的访问顺序。
队列(Queue):一种有序的元素集合,支持从尾部添加元素,从首部删除元素,实现先入先出的访问顺序。
数学集合(Set):一组没有重复元素的集合。
映射(Map):一组存放(键,值)对的集合,其中每一个键都对应着一个值。
节点:构成链表的单个元素;每个节点可以存储一个数据值。
链表:链表(Linked list)是一种结合类型,它将元素存储在节点中,而所有节点又连接成一条链。
迭代器:允许用户以顺序的方式高效的访问链表中每个元素的一种特殊对象。
抽象数据类型(ADT):对某种数据类型以及该类型允许的各种操作的一个规定。
迭代(迭代的):一种用循环来描述需要重复进行的操作的编程技术。
递归(递归的):一种通过调用某个方法来描述需要重复进行的操作的编程技术,该方法的一个基本特点是:它可以调用它自己。
递归方法的结构:每一个递归方法有两个重要组成部分;一个基本情况和一个递归情况。
基本情况:一种简单到不需要递归调用就可以直接解决的情况。
递归情况:一种需要把整个问题转化成一个相同种类的,比较简单的,而且可以通过递归调用来解决问题的情况。
调用栈:用来跟踪所调用方法的顺序的内部结构。
(递归)回溯法:一种搜索问题解的通用算法,它先找出可能的候选解,一旦确定某个(某些)候选解不适合,就立刻放弃进一步尝试(回溯)。
二分法查找:一种在有序列表中查找某个值的算法,它每次都将待查找的空间分为两半,在其中一半继续查找。
复杂度:衡量一段代码使用时间、内存、硬盘空间等计算资源的紧凑程度的属性。
复杂度类型:一类所需资源开销与输入规模之间的关系相似的算法。
要确定一段代码的复杂度,我妈妈值需要首先找到它执行次数最多的那一行代码,确定他的执行次数,从中取出 N 的最高项即可。例如,如果执行次数最多的代码 被执行了 (2NNN + 4N)次,那么该算法属于“N×N×N类型“的复杂度,或简记为 O(NNN) 。这种以大写字母O开头的表示法被称为”大写O表示法“。
以下是一些常用复杂度类型:
1)常数时间或O(1)算法,该类型算法的运行时间与输入的大小无关。
2)对数时间或O(log N)算法,该类算法总是不停地将问题空间减半,直到问题被解决。二分法查找是对数时间算法的一个例子。
3)线性或O(N)算法,该类算法的运行时间与N成比例(当N加倍时,运算时间也加倍)。很多需要逐个处理数据集合中每个元素的算法都是线性复杂度类型, 例如,计算一组数值的个数、和、平均值、最大值后上下边界。
4)对数-线性或O(N logN)算法,该类算法一般包括对数算法与线性操作的结合。例如,对输入数据集中的每一个元素进行一次对数运算。很多高效的排序算法,例如归并排序,都输入对数-线性复杂度类型。
5)平方或O(NN)算法,该类算法的运行时间与输入规模N的平法成比例。当输入规模N加倍后,二次算法的时间开销会变为原来的4倍。
6)立方或O(NN*N)算法,该类算法的运行时间与输入规模N的立方成比例。该类算法通常对输入数据进行三重嵌套。例如计算两个N×N矩阵的乘法或计算一个很大的Point数组中共线的三个点数目的算法就是该类的例子。
7)指数或O(2^n)算法,该类算法的运行时间与输入规模N的指数2^N成比例。这意味着输入规模增加1,算法运行时间就要加倍。该类算法的一个例子是输入给定数据集的幂集,也就是它所有的子集。指数算法的效率很低,通常值用来处理很小的输入数据。
内部类:在另一个类中声明的类。内部类的对象可以访问外部类的方法和字段。
垃圾收集器(GC):java运行时环境中的一个进程,定期释放不再被引用的对象所使用的内存。
散列函数:一个能够快速完成元素值与其在数组中存储索引的映射的函数。
散列表:利用散列函数确定元素存储索引的数组。
冲突:当两个或更多不同元素经散列函数处理后得到相同的结果,使得它们都要存储到散列表中同一个位置的情况。
探测技术:一种通过查找并使用其它空闲位置索引来解决散列表冲突问题的技术。
独立链:在散列表中每个索引位置存储一个列表而非单个值来解决冲突。
再散列:一种通过扩大散列表的容量来存储更多元素,或提高存取效率的技术。
负载因子:将散列表元素数量与内部数组容量的比值定义为负载因子。
优先级队列(Priority queue):一种队列集合,每个元素都带有优先级或重要程度信息,并根据优先级访问或删除队列中的元素。
堆(heap):一种父子节点之间满足特定顺序的树形数据结构。在最小堆中,父节点的值总是小于等于所有子节点的值;在最大堆中,父节点的值总是大于等于所有子节点的值。
起泡技术:通过上移或下移元素使堆满足父子节点之间的大小关系。
////end
O
javaSE基础(三)的更多相关文章
- javaSE基础07
javaSE基础07 一.static静态修饰符 用了static修饰的变量就会变成共享的属性,只会初始化一次,在内存中只存在一个,并且每个对象都可以访问,存放在方法区(数据共享区) 1.1 stat ...
- javaSE基础06
javaSE基础06 一.匿名对象 没有名字的对象,叫做匿名对象. 1.2匿名对象的使用注意点: 1.我们一般不会用匿名对象给属性赋值的,无法获取属性值(现阶段只能设置和拿到一个属性值.只能调用一次方 ...
- javaSE基础05
javaSE基础05:面向对象 一.数组 数组的内存管理 : 一块连续的空间来存储元素. Int [ ] arr = new int[ ]; 创建一个int类型的数组,arr只是一个变量,只是数组的一 ...
- javaSE基础04
javaSE基础04 一.三木运算符 <表达式1> ? <表达式2> : <表达式3> "?"运算符的含义是: 先求表达式1的值, 如果为真, ...
- javaSE基础03
javaSE基础03 生活中常见的进制:十进制(0-9).星期(七进制(0-6)).时间(十二进制(0-11)).二十四进制(0-23) 进制之间的转换: 十进制转为二进制: 将十进制除以2,直到商为 ...
- javaSE基础02
javaSE基础02 一.javac命令和java命令做什么事情? javac:负责编译,当执行javac时,会启动java的编译程序,对指定扩展名的.java文件进行编译,生成了jvm可以识别的字节 ...
- javase基础复习攻略《十》
按照计划本篇为大家总结JAVA的网络编程,什么叫网络编程呢?网络编程!=网站编程,对于这一点大家一定要注意,很多小朋友都曾经这么认为.既然谈到网络编程,咱们先了解一下网络的基础知识,什么是计算机网络? ...
- 基础1 JavaSe基础
JavaSe基础 1. 九种基本数据类型的大小,以及他们的封装类 boolean 无明确指定 Boolean char 16bits Character byte 8bits Byte short 1 ...
- java学习之路之javaSE基础2
java学习之路之javaSE基础2 所有的代码都是引用他人写的. 1.逻辑运算符 //&,|,^,! //int x = 10; //5 < x < 15 //x > 5 ...
- java学习之路之javaSE基础1
<h2>java学习之路之javaSE基础1</h2> <div> ###01.01_计算机基础知识(计算机概述)(了解)* A:什么是计算机?计算机在生活中的应用 ...
随机推荐
- [Python3网络爬虫开发实战] 2.4-会话和Cookies
在浏览网站的过程中,我们经常会遇到需要登录的情况,有些页面只有登录之后才可以访问,而且登录之后可以连续访问很多次网站,但是有时候过一段时间就需要重新登录.还有一些网站,在打开浏览器时就自动登录了,而且 ...
- CSRF之Ajax请求
A:Ajax提交数据是,携带的CSRF在data中: <form method="POST" action="/csrf.html"> {% csr ...
- 配置bean
[bean配置] 在XML文件中通过bean节点来配置bean <!-- 配置bean class: bean的全类名,通过反射的方式在IOC容器中创建bean,所以要求bean中必须有无参的构 ...
- java 几种拼接字符串的效率问题
拼接字符串,大致有3个class可以用,他们是String, StringBuffer,StringBuilder, StringBuilder是1.5中来代替StringBuffer的.检验方法如下 ...
- js变量类型详解
<html> <title>js变量类型详解</title> <meta http-equiv="content-type" conten ...
- jquery动态绑定元素
按照正常给静态元素绑定事件的写法换成给动态元素绑定事件会不管用,要用下面的方式: 简单说就是给要绑定元素的父元素绑定事件,参数中指明要绑定该父元素下面的哪个元素就行,这样就不管你这个元素是不是新增的, ...
- 开发辅助网站---programcreek
开发中让我们事半功倍的工具网站,开发中经常遇到api如何使用,很好的解决这个问题.java代码api案例网,提供最简单的demo,很不错分享一下,大家可以用用. http://www.programc ...
- C++对拍数据生成
#include<map> #include<ctime> #include<queue> #include<cmath> #include<cs ...
- idea使用之maven本地索引更新
idea使用起来的确挺顺手的,但遇到一些问题时,直接百度很难有答案,只能自己慢慢摸索了. 今天在倒腾idea仓库索引的时候,就出事情啦. 先说idea更新本地仓库索引吧,打开settings--> ...
- hdu -1251 统计难题(字典树水题)
http://acm.hdu.edu.cn/showproblem.php?pid=1251 建树之后 查询即可. G++提交 ME不知道为什么,c++就对了. #include <iostre ...