首页 > 编程语言 >扎实打牢数据结构算法根基,从此不怕算法面试系列之008 week01 02-08 通过常见算法,对常见的时间复杂度做梳理

扎实打牢数据结构算法根基,从此不怕算法面试系列之008 week01 02-08 通过常见算法,对常见的时间复杂度做梳理

时间:2023-04-19 20:57:24浏览次数:58  
标签:02 10 int 复杂度 常见 算法 logn data

1、线性查找法的复杂度

public static <E> int search(E [] data,E target){
    for (int i = 0; i < data.length; i++)
        if (data[i].equals(target))
            return i;
    return -1;
}

很容易看出,这个算法的复杂度为 O(n)


2、一个数组中的元素可以两两组成哪些数据对? O(n²)

需要实现一个算法,这个算法用于:找到一个数组中的元素可以两两组成哪些数据对?
①、在不要求顺序的情况下,即data[i],data[j]和data[j],data[i]看作同一个数据对;
②、每一个元素自己和自己不能组成数据对,即data[i],data[i]不是数据对。

这个算法的代码如下:

  for(int i=0;i<data.length;i++)
    for (int j=i+1; j< data.length;j++) 
        //获得一个数据对 (data[i],data[j])

注意,j从i+1开始。
可以分析得出,这个算法的复杂度为O(n²)

虽然是2重循环,但是循环执行的次数并不是nn,其实执行的次数为1/2n²,但是1/2作为常数,不重要。


3、遍历一个n*n的二维数组 O(n²)

我们来实现一个需求:遍历一个n*n的二维数组 ,代码如下:

for (int i = 0; i < n; i++)
    for (int j = 0; j < n; j++) 
        //遍历到A[i][j]

上述代码的时间复杂度是O(n²)
注:

在做复杂度分析时,一定要明确n是谁?

假设遍历一个aa的二维数组 O(a²)=O(n)
而 a
a=n,上面的n表示的是维度为n(每一个维度的元素个数都是n),下面的n表示的是元素总数为n。

 for (int i = 0; i < a; i++)
    for (int j = 0; j < a; j++) 
        //遍历到A[i][j]

看时间复杂度也好,总结时间复杂度也好,一定一定要明确n到底谁?

mark


4、数字n的二进制位数 O(logn)

我们来实现一个需求:求解数字n的二进制位的位数?
如何理解位数,我们来举个例子,一看就懂:
16这个数字的10进制位数有几位?
有2位嘛,1和16

520这个数字的10进制位数有几位?
3位嘛,5、2、0


我们看下这个算法的实现的伪码:

while(n){
    n%2 //n的二进制中的一位
    n/=2;
}

上面伪码的时间复杂度是:O(logn)


不同的底数相差的只是一个常数而已,可以复习下高中数学的换底公式;

所以,最终我们对数复杂度都是不关注底数的,都是O(logn)。


注意,分析算法复杂度的时候,也不能只看循环个数。

这里n每次除以2,而不是每次减1,所以它到0的速度非常快……所以不是O(n)级别,而是O(logn)级别。


5、求解数字N的所有约数? O(n)、O(√n) :根号n

我们来实现一个需求:我们来实现一个需求。
首先需要回顾下约数的概念,假设a是n的约数,表示n除以a没有余数,即n可以整除a

for (int i = 1; i <= n ; i++)
    if (n%i==0)
        // i是n的一个约数

接着,我们来对上述算法做一个优化:

 for (int i = 1; i*i <= n ; i++)
    if (n%i==0) //i和n/i都是n的约数,同时找到两个约数(需要排除i=n/i的情况)

再次强调,看算法复杂度,不能看循环个数。
上述两个算法都是一重循环,但他们循环的结束条件不同,优化前的算法是i<=n,优化后的是i*i<n,所以实际上这两个算法的执行次数是非常不同的。
一个是n,一个是根号n。

mark

所以这个算法的实现,有2种复杂度:
O(n)和O(√n) :根号n。。

6、求所有长度位n的二进制数字的个数? O(2^n);2的n次方

我们来实现一个需求:求所有长度位n的二进制数字的个数?


如何理解这个题目,比如,所有长度位3的二进制数字,一共有几个?

一共有8个,分别是从0到7
0、1、10、11、100、101、110、111

比如,所有长度位4的二进制数字。
一共有16个,分别是从0到15
0、1、10、11、100、101、110、111
1000、1001、1010、1011、1100、1101、1110、1111


这里我们就是用排列组合来得到,长度为n,相当于有n个位置,每个位置或者填0,或者填1;
每个位置有2种选择,现在有n个位置,则相当于n个2连续乘起来
222……222=2^n,是2的n次方。

所以,这个算法的复杂度为:
O(2^n),是2的n次方

7、长度为n的数组的所有排列 O(n!)

我们来是实现一个需求,求解长度为n的数组的所有排列个数。

举个例子,比如,1、2、3的排列个数为6,
1、2、3、4的排列个数为24。
这里用到了数学中的全排列公式。

全排列个数,n!;
所以这个算法的复杂度为:O(n!)

O(2^n),n次方复杂度和 O(n!)阶乘复杂度,都是非常高,性能非常差的复杂度。


O(2^n),当n为10,基本就是1000了,程序员都熟悉,实际是1024,
当n为20,基本就是1000*1000=100w了,普通程序员都期望追求的年薪数字是吧哈哈
当n为20,基本就是10亿了,你的10个小目标?这么小的目标,MosesMin可不敢有,哈哈哈
甚至当n为100时,科学家统计,它的大小就接近于宇宙中所有原子的个数那么多个了……
所以指数级别是一个非常恐怖的增长。


通常,算法设计上,如果n<=20,可以考虑指数级别的复杂度;如果n>20,指数级别的复杂度是承受不起的。
所以算法设计上,要尽可能避免指数级别的复杂度;
而阶乘的复杂度就更高了,更是需要全力避免。
阶乘级别也一样,n<20可以考虑,大于20就不能考虑了。


8、判断n是否是偶数? O(1)

判断n是否是偶数?伪码如下:

return n%2 == 0

只有一行代码,所以复杂度为:O(1)

9、常见算法复杂度总结

结论很重要,要记住:
O(1)<O(logn)<O(√n)<O(n)<O(nlogn)<O(n²)<O(2^n)<O(n!)

mark

注意;
O(nlogn)很重要。

O(logn)<O(√n)如何比较,不做数学推导了,举个例子记一下:
log以2为底的1000是多少,大概是10,因为2的10次方是1024嘛,所以log以2为底的1000大概是10;
1000的根号值是30多,因为30*30=900嘛,所以大概是30。
10<30,所以我们这样记得:O(logn)<O(√n)

logn比n快很多。
n取100w,logn大概是20次左右,而n要100w次;
数据规模100w的时候,n和logn的性能差距在5w倍。

logn和nlogn这样的算法,会非常多,需要学习。
空间复杂度和时间复杂度的计算基本差不多。

时间更值钱,空间不太值钱;
所以算法设计更重视时间复杂度,所以很多算法设计思想的本质更多是以空间换时间。
即:可不可以考虑使用缓存等等.

我们常见算法的复杂度梳理就到这里。

标签:02,10,int,复杂度,常见,算法,logn,data
From: https://www.cnblogs.com/xlfcjx/p/17334573.html

相关文章

  • 2023-04-19:给定一个非负数组arr 任何两个数差值的绝对值,如果arr中没有,都要加入到arr里
    2023-04-19:给定一个非负数组arr任何两个数差值的绝对值,如果arr中没有,都要加入到arr里然后新的arr继续,任何两个数差值的绝对值,如果arr中没有,都要加入到arr里一直到arr大小固定。请问最终arr长度是多少。1<=arr的长度<=10^50<=arr的数值<=10^5来自国外题目论坛。答......
  • DAMA认证|2021年大数据存储安全如何管理?
    在大数据(Bigdata)时代,通过互联网、社交网络、物联网,人们能够及时全面地获得大信息。同时,信息自身存在形式的变化与演进,也使得作为信息载体的数据以远超人们想象的速度迅速膨胀。随着Ai、5G、IoT的兴起和发展,全球每年产生的数据以爆发的态势急速增长。数据存储是基础且关键......
  • Codeforces Round 850 (Div. 2, based on VK Cup 2022 - Final Round) E. Monsters (h
    传送门详细题解传送门  抄的ygg代码,向在这里说一下刚开始没看懂的部分。  求答案的时候是把所有的当前为止的所有数值加起来减去一个从1开始并且公差为1的等差数列的前size项和。其中size是当前最多能用到哪个位置,满足前size项能构成1,2,3,....,sz这样的形式。  假设我们......
  • Kraken序列分类算法
    当然可以!kraken是一种流行的高效序列分类器,使用k-mer(k个连续碱基组成的子串)方法对不同分类下的序列进行分类。以下是kraken序列分类算法简要说明:数据预处理首先,kraken会将参考数据库中的序列分割为固定长度的k-mers,这些k-mer会被记录到一个查询表中。样品序列匹配krake......
  • 20230418 >windows11 slmgr/ ato 命令和kms server
    Problems:1使用win11不打算使用微软账户,如何绕过2重装Windows11或者用virtualmachines搬运都得用到的,如何临时激活。这个作为testing用途,请勿用作商业用途。 SolutionstepA:重装的时候会遇到windows11在oobe界面下要求登入Microsoft账号,但由于只是作为测试用途......
  • 2023.1.19每日总结
    <%@pageimport="wangzhan.Pd_zhengce"%><%@pageimport="wangzhan.Thesql"%><%@pagelanguage="java"contentType="text/html;charset=UTF-8"pageEncoding="UTF-8"%><!DOCTYPEhtm......
  • 02 绘制简单几何图形
    图形渲染管线与绘制简单几何图形1.图形渲染管线回顾简要回顾一下GAMES101中闫老师提到的图形渲染管线。图形渲染管线可以理解为,将原始的3维图形数据经过一系列变化处理后,转换为2维坐标,再将2维坐标转换为实际的屏幕像素的过程。这一过程可以简单的描述为:首先我们要做的是输......
  • 2023/4/19
    今日站立会议,对任务进度进行报告,规划下一步如何进行,如何进行供货商数据库的对接,如何对数据进行处理。如何显示数据。 ......
  • 替换算法与写策略
    一.基础认知1.个人理解替换算法是用于管理高速缓存(Cache)中数据的一种策略,当高速缓存已满并需要为新的数据腾出空间时,替换算法会决定哪些数据应该被从高速缓存中替换出去。2.基础认知首先,我们需要知道计算机的组成原理,在其中计算机可以划分为cache-主存和主存-辅存两种层级结构......
  • 2023年4月19日周三
    计划找杨哥问邮件发送的问题研究如何实现权限控制新增修改接口的,这属于下周的审核权限了继续读懂代码,补充相关知识收集免费接口执行09点12分  继续看完英语那个10点02分  花钱买了还是,每天早上端电脑学吧,开始搞毕设11点32分  看了半天学校,16点42分  解决mo......