IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 一、Java数据结构与算法---算法分析(讲解与代码) -> 正文阅读

[Java知识库]一、Java数据结构与算法---算法分析(讲解与代码)

算法分析(时间为尊,空间为王)

在Java中更多考虑的是时间复杂度,由于开发环境的原因,空间复杂度考虑的因素较为宽泛,如果在嵌入式语言中,由于开发内存的大小,需要考虑空间复杂度,降低代码的冗余性。

1.1算法的时间复杂度分析

计算算法时间耗费情况,分为
①事后分析估算方法:使用System.currentTimeMillis()来得到该代码的运行所需时间。
②事前分析估算方法:
运行所消耗的时间取决于下列因素:
1.算法采用的策略和方案;
2.编译产生的代码质量;
3.问题的输入规模(所谓的问题输入规模就是输入量的多少);
4.机器执行指令的速度;

下面展示一些 事后分析估算方法举例

public static void main(String[] args) {
	long start = System.currentTimeMillis();
	int sum = 0;
	int n=100;
	for (int i = 1; i <= n; i++) {
		sum += i;
	}
	 System.out.println("sum=" + sum);
	long end = System.currentTimeMillis();
	System.out.println(end-start);
}

1.1.1 函数渐近增长

比较算法随着输入规模的增长量时,可以有以下规则:
1.算法函数中的常数可以忽略;
2.算法函数中最高次幂的常数因子可以忽略;
3.算法函数中最高次幂越小,算法效率越高。

1.1.2算法时间复杂度

1.1.2.1 大O记法
**定义:**在进行算法分析时,语句总的执行次数T(n)是关于问题规模n的函数,进而分析T(n)随着n的变化情况并确定T(n)的量级。算法的时间复杂度,就是算法的时间量度,记作:T(n)=O(f(n))。

**时间复杂度:**它表示随着问题规模n的增大,算法执行时间的增长率和f(n)的增长率相同,称作算法的渐近时间复杂度。

下面展示一些 算法一:记为O(1)

public static void main(String[] args) {
	int sum = 0;//执行1次
	int n=100;//执行1次
	sum = (n+1)*n/2;//执行1次
	System.out.println("sum="+sum);
}

下面展示一些 算法二:记为O(n)

public static void main(String[] args) {
	int sum = 0;//执行1次
	int n=100;//执行1次
	for (int i = 1; i <= n; i++) {
		sum += i;//执行了n次
	} 
System.out.println("sum=" + sum);
}

下面展示一些 算法三:记为O(n^2)

public static void main(String[] args) {
	int sum=0;//执行1次
	int n=100;//执行1次
	for (int i = 1; i <=n ; i++) {
		for (int j = 1; j <=n ; j++) {
			sum+=i;//执行n^2次
			}
	} 
	System.out.println("sum="+sum);
}

基于我们对函数渐近增长的分析,推导大O阶的表示法有以下几个规则可以使用:
1.用常数1取代运行时间中的所有加法常数;
2.在修改后的运行次数中,只保留高阶项;
3.如果最高阶项存在,且常数因子不为1,则去除与这个项相乘的常数;

1.1.2.2常见的大O阶
1.线性阶
一般含有非嵌套循环涉及线性阶,线性阶就是随着输入规模的扩大,对应计算次数呈直线增长,循环的时间复杂度为O(n),因为循环体中的代码需要执行n次.

2.平方阶
一般嵌套循环属于这种时间复杂度.

3.立方阶
一般三层嵌套循环属于这种时间复杂度.

4.对数阶
下面展示一些 对数阶举例

int i=1,n=100;
while(i<n){
	i = i*2;
}

5.常数阶
一般不涉及循环操作的都是常数阶,因为它不会随着n的增长而增加操作次数。

1.1.2.3 函数调用的时间复杂度分析

下面展示一些 最终main方法的时间复杂度为O(n^2)

public static void main(String[] args) {
	int n=100;
	show(n);
	for (int i = 0; i < n; i++) {
		show(i);
	} 
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < n; j++) {
			System.out.println(j);
		}
	}
}
	private static void show(int i) {
	for (int j = 0; j < i; i++) {
		System.out.println(i);
	}
}

1.1.2.4 最坏情况(一般按照最坏结果进行判断)

下面展示一些 有一个存储了n个随机数字的数组,请从中查找出指定的数字

public int search(int num){
	int[] arr={11,10,8,9,7,22,23,0};
	for (int i = 0; i < arr.length; i++) {
		if (num==arr[i]){
			return i;
		}
	}
	 return -1;
}

**最好情况:**查找的第一个数字就是期望的数字,那么算法的时间复杂度为O(1)
**最坏情况:**查找的最后一个数字,才是期望的数字,那么算法的时间复杂度为O(n)

1.2 算法的空间复杂度分析

1.2.1java中常见内存占用

1.基本数据类型内存占用情况:
在这里插入图片描述
2.计算机访问内存的方式都是一次一个字节
3.一个引用(机器地址)需要8个字节表示:
例如: Date date = new Date(),则date这个变量需要占用8个字节来表示
4.创建一个对象,比如new Date(),除了Date对象内部存储的数据(例如年月日等信息)占用的内存,该对象本身也有内存开销,每个对象的自身开销是16个字节,用来保存对象的头信息。
5.一般内存的使用,如果不够8个字节,都会被自动填充为8字节:
6.java中数组被被限定为对象,他们一般都会因为记录长度而需要额外的内存,一个原始数据类型的数组一般需要24字节的头信息(16个自己的对象开销,4字节用于保存长度以及4个填充字节)再加上保存值所需的内存。

1.2.2 算法的空间复杂度

对指定的数组元素进行反转,并返回反转的内容。
下面展示一些 方式一:对指定的数组元素进行反转,并返回反转的内容,空间复杂度O(1)

public static int[] reverse1(int[] arr){
	int n=arr.length;//申请4个字节
	int temp;//申请4个字节
	for(int start=0,end=n-1;start<=end;start++,end--){
		temp=arr[start];
		arr[start]=arr[end];
		arr[end]=temp;
	} 
	return arr;
}

下面展示一些 方式二:对指定的数组元素进行反转,并返回反转的内容,空间复杂度O(n)

public static int[] reverse2(int[] arr){
	int n=arr.length;//申请4个字节
	int[] temp=new int[n];//申请n*4个字节+数组自身头信息开销24个字节
	for (int i = n-1; i >=0; i--) {
		temp[n-1-i]=arr[i];
	} 
	return temp;
}
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-08-06 09:29:41  更:2021-08-06 09:30:23 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/11 17:10:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码