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:什么是计算机?计算机在生活中的应用 ...
随机推荐
- phpstorm破解激活码
一.将“0.0.0.0 account.jetbrains.com”添加到hosts文件中 二.浏览器打开 http://idea.lanyus.com,点击页面中的“获得注册码”,然后在注册时切换至 ...
- 九度oj 题目1206:字符串连接
题目1206:字符串连接 时间限制:1 秒 内存限制:128 兆 特殊判题:否 提交:5117 解决:2373 题目描述: 不借用任何字符串库函数实现无冗余地接受两个字符串,然后把它们无冗余的连接起来 ...
- ORACLE数据库查看执行计划的方法
一.什么是执行计划(explain plan) 执行计划:一条查询语句在ORACLE中的执行过程或访问路径的描述. 二.如何查看执行计划 1: 在PL/SQL下按F5查看执行计划.第三方工具toad等 ...
- 状态压缩DP总结
POJ1185 炮兵部队问题: 在平原上才能放置炮兵,每个炮兵的上下左右2格之内都不能出现别的炮兵 可以考虑在当前行放置炮兵它的右侧和下侧绝对不会出现炮兵即可,左侧和上侧就能省去考虑 明显的状态压缩d ...
- [luoguP1042] 乒乓球(模拟)
传送门 终于过了这sb题了. 当初我连这道题都A不了(╯▔皿▔)╯ 代码 #include <cstdio> #include <iostream> #define N 100 ...
- 【转】关于LIS和一类可以用树状数组优化的DP 预备知识
原文链接 http://www.cnblogs.com/liu-runda/p/6193690.html 预备知识 DP(Dynamic Programming):一种以无后效性的状态转移为基础的算法 ...
- 593. Valid Square
Problem statement: Given the coordinates of four points in 2D space, return whether the four points ...
- spring-session(一)揭秘
前言 在开始spring-session揭秘之前,先做下热脑(活动活动脑子)运动.主要从以下三个方面进行热脑: 为什么要spring-session 比较traditional-session方案和s ...
- iOS 数据库操作崩溃提示“ int rc = sqlite3_step([_statement statement]);”或者提示“ rc = sqlite3_step(pStmt);”
数据库崩溃崩溃提示“ int rc = sqlite3_step([_statement statement]);”或者提示“ rc = sqlite3_step(pStmt);”的时候,可 ...
- Codeforces 631C Report【其他】
题意: 给定序列,将前a个数进行逆序或正序排列,多次操作后,求最终得到的序列. 分析: 仔细分析可以想到j<i,且rj小于ri的操作是没有意义的,对于每个i把类似j的操作删去(这里可以用mult ...