数据结构和算法day1(Java)
1.什么是数据结构?
数据结构就是把数据元素按照一定的关系组织起来的集合,用来组织和存储数据。
1.2.数据结构的分类:
逻辑结构 和物理结构
逻辑结构:
集合结构(无关系)、线性结构(一对一)、树形结构(一对多)、图形结构(多对多)
物理结构:
顺序存储结构(不方便插入)、链式结构(不方便查找)(指针)
1.3.什么是算法?
根据一定的条件,对数据进行计算,得到需要的结果。(用(最佳的)数学模型解决问题)
举例:云南到北京的出行方式。在北京买房的购买方式
1.4算法的初步体验
优秀的算法:
最少的时间,占用最少的内存
举例:
计算1-100求和。for循环累加 VS 高斯公式
计算10的阶乘。暴力算法 VS 递归
2.算法分析
2.1.算法的时间复杂度分析(分析计算时间)
事后分析方法:
使用测试程序计算执行时间
有弊端:干扰执行时间,运行环境不同
事前分析法(未来要用的方法):
1)算法采用的策略和方法(程序员可以干预)
2)编译产生的代码质量(由编译器决定)
3)问题的输出规模(取决于实际需求)
4)机器执行指令的速度(不能干预)
2.1.2函数渐进增长(比较算法的相对增长率,相对增长率越小,算法的效率越高)
规律:
随着输入规模的增大,算法的常数操作可以忽略不计
随着输入规模的增大,与最高次项相乘的乘数可以忽略不计
最高次数项的指数大的,随着n的增长,结果也会增长得特别快
算法中n的最高次幂越小,算法效率越高
2.1.3大O计法
前提:程序的执行次数=程序的执行时间
T(O)=O(f(n))
表示
3次……O(1)
n+3次 O(n)
n^2+2 O(n^2)
表示方法:
用常数1取代运行时间中的所有加法常数
在修改后的的运行次数中,只保留高阶乘
如果最高阶乘存在,且常数因子不为1,则去除这个项相乘的常数
2.1.3.1常见的大0阶
1)线性阶
一般含有非嵌套循环(一个for循环执行n次)
2)平方阶
双层嵌套循环(例如两个个for循环每个都执行n次)
3)立方阶
三层嵌套循环
4)对数阶
范围内乘法累加计算循环,计算循环次数则需要用log计算
规律:可以忽略底数
5)常数阶
复杂度:
O(1)<O(logn)<O(nlogn)<O(n^2)<O(n^3)............
2.1.4函数调用的时间复杂度分析
具体情况具体分析,灵活运用
2.1.5 最坏情况(最好,最坏,平均)
2.2空间复杂度分析(嵌入式开发)Java默认是考虑时间复杂度
1)Java的数据类型占用内存情况
byte ,1
short,2
int,4
long,8
float,4
double,8
boolean,1
char,2
2)计算机访问内存都是一次一字节
3)一个引用需要8个字节
4)创建对象16个字节
5)不够8字节,都会自动填充为8字节
6)数组,保存数组长度,不够8的倍数,填充8字节
2.2.案例 数组返转,反会数组
数据结构和算法day1(Java)的更多相关文章
- 数据结构与算法【Java】02---链表
前言 数据 data 结构(structure)是一门 研究组织数据方式的学科,有了编程语言也就有了数据结构.学好数据结构才可以编写出更加漂亮,更加有效率的代码. 要学习好数据结构就要多多考虑如何将生 ...
- 数据结构与算法【Java】03---栈
前言 数据 data 结构(structure)是一门 研究组织数据方式的学科,有了编程语言也就有了数据结构.学好数据结构才可以编写出更加漂亮,更加有效率的代码. 要学习好数据结构就要多多考虑如何将生 ...
- 数据结构与算法【Java】05---排序算法总结
前言 数据 data 结构(structure)是一门 研究组织数据方式的学科,有了编程语言也就有了数据结构.学好数据结构才可以编写出更加漂亮,更加有效率的代码. 要学习好数据结构就要多多考虑如何将生 ...
- 数据结构与算法【Java】08---树结构的实际应用
前言 数据 data 结构(structure)是一门 研究组织数据方式的学科,有了编程语言也就有了数据结构.学好数据结构才可以编写出更加漂亮,更加有效率的代码. 要学习好数据结构就要多多考虑如何将生 ...
- 常用数据结构及算法C#/Java实现
常用数据结构及算法C#实现 1.冒泡排序.选择排序.插入排序(三种简单非递归排序) ,, , , , , , , , , }; //冒泡排序 int length = waitSort.Length; ...
- 数据结构与算法之java语言实现(一):稀疏数组
一.概念&引入 什么是稀疏数组? 稀疏数组是面对一个二维数组中有众多重复元素的情况下,为了节省磁盘空间,将此二维数组转化为更加节省空间的一种数组,我们叫他稀疏数组. 只是听概念或许会看不明白, ...
- 数据结构和算法(java版本)学习指南
1 数据结构和算法内容介绍 2 数据结构和算法的概述 3 稀疏数组SparseArray
- 数据结构与算法—二叉排序树(java)
前言 前面介绍学习的大多是线性表相关的内容,把指针搞懂后其实也没有什么难度.规则相对是简单的. 再数据结构中树.图才是数据结构标志性产物,(线性表大多都现成api可以使用),因为树的难度相比线性表大一 ...
- 数据结构和算法(Java版)快速学习(线性表)
线性表的基本特征: 第一个数据元素没有前驱元素: 最后一个数据元素没有后继元素: 其余每个数据元素只有一个前驱元素和一个后继元素. 线性表按物理存储结构的不同可分为顺序表(顺序存储)和链表(链式存储) ...
- 数据结构和算法(Java版)快速学习(数组Array)
Java数组 在Java中,数组是用来存放同一种数据类型的集合,注意只能存放同一种数据类型. 用类封装数组实现数据结构 数据结构必须具有以下基本功能: ①.如何插入一条新的数据项 ②.如何寻找某一特定 ...
随机推荐
- re、base64的结合使用爬取豆瓣top250
一.缘由 对于豆瓣的这个网站,记得使用了不少于三种的爬取和解析方式来进行的.今天的这种解析方式是我使用起来较为顺手,后来就更喜欢使用xpath解析,但是这两种也需要掌握. 二.代码展示 '''爬取豆瓣 ...
- jQuery基本使用
目录 一:jQuery查找标签 1.基本选择器 二:分组与嵌套 三:组合选择器 四:jQuery基本筛选器 五:属性选择器 1.属性标签 六:JQuery表单筛选器 1.type属性 2.表单对象属性 ...
- SQLMap入门——判断是否存在注入
假设目标注入点是http://127.0.0.1/sqli-labs-master/Less-1/?id=1,判断其是否存在注入的命令如下: python sqlmap.py -u http://12 ...
- python 爬站长素材网页图片
一.我们要用python第三方库: import requests import re 二.找到自己感兴趣的网页图片: for i in range(1,2): url = "https:/ ...
- Vue中实现自定义excel下载
目录 第一种:后端生成excel 第二种:前端合成excel 总结 参考资料 最近在工作中遇到一个需求,就是需要在前端实现一个错误模板Excel的下载功能. 实现下载有两种方式,一种是后端生成一个ex ...
- [深度学习] CNN的基础结构与核心思想
1. 概述 卷积神经网络是一种特殊的深层的神经网络模型,它的特殊性体现在两个方面,一方面它的神经元间的连接是非全连接的, 另一方面同一层中某些神经元之间的连接的权重是共享的(即相同的).它的非全连接和 ...
- Crossplane - 比 Terraform 更先进的云基础架构管理平台?
️URL: https://crossplane.io/ Description: 将云基础架构和服务组成自定义平台 API 简介 在 11 月的 KCD 上海现场,听了一场阿里云的工程师关于他们自己 ...
- _Bool類型
_Bool類型:布爾變量,其值只有1(真)和0(假).是C語言中的變量名,C語言中所有的非0數字都被視爲真. 給布爾變量取一個能表示真或假值的變量名是一種常見的做法. 1 /*boolean.c--使 ...
- vue-echarts数据可视化实现自适应屏幕进行缩放,这个我写了两篇文章,一个用了vue-echarts,一个直接用的charts ,我可真机智 啊~~~
使用这个后可以实现屏幕自适应 效果如下 <template> <div style="width:100%;height:20rem" ref="res ...
- Unity之正确设置手机显示布局&&获取手机朝向
目录 Unity之正确设置手机显示布局 && 获取手机朝向 前言 开篇 Unity版本及使用插件 正题 设置手机屏幕显示布局.Screen.orientation 获取手机当前朝向.I ...