acwing算法基础之时空复杂度分析

目录

  • [1 基础知识](#1 基础知识)
  • [2 模板](#2 模板)
  • [3 工程化](#3 工程化)

1 基础知识

(一)

由数据范围反推算法。

C++中题目给出的要求时间是1秒或2秒计算出结果,而1秒内C++可以执行 1 0 7 ∼ 1 0 8 10^7 \sim 10^8 107∼108次操作。故需要把时间复杂度控制在 1 0 8 10^8 108以内。

给定数目范围 n n n,有如下情况,

  1. 当 n ≤ 30 n\leq 30 n≤30时,指数级别,可以考虑的算法有:dfs+剪枝,状态压缩dp。
  2. 当 n ≤ 1 0 2 n \leq 10^2 n≤102时,可以接受的最大的时间复杂度为 O ( n 3 ) O(n^3) O(n3),那么可以考虑的算法有:floyd,dp。
  3. 当 n ≤ 1 0 3 n\leq 10^3 n≤103时,可以接受的最大的时间复杂度为 O ( n 2 l o g n ) O(n^2logn) O(n2logn),那么可以考虑的算法有:dp,二分。
  4. 当 n ≤ 1 0 4 n \leq 10^4 n≤104时,可以接受的最大的时间复杂度为 O ( n n ) O(n\sqrt{n}) O(nn ),那么可以考虑的算法有:块状链表。
  5. 当 n ≤ 1 0 5 n\leq 10^5 n≤105时,可以接受的最大的时间复杂度为 O ( n l o g n ) O(nlogn) O(nlogn),那么可以考虑的算法有:排序算法(快速排序、归并排序、堆排序),线段树,树状数组,set/map,heap,dijkstra + heap,spfa,求凸包,求半平面交,二分。
  6. 当 n ≤ 1 0 6 n \leq 10^6 n≤106时,可以接受的最大的时间复杂度为常数较小的 O ( n l o g n ) O(nlogn) O(nlogn),那么可以考虑的算法有:hash,双指针扫描,kmp,AC自动机,排序算法(快速排序、归并排序、堆排序),树状数组,heap,dijkstra,spfa。
  7. 当 n ≤ 1 0 7 n\leq 10^7 n≤107时,可以接受的最大的时间复杂度为 O ( n ) O(n) O(n),那么可以考虑的算法有:双指针扫描,kmp,AC自动机,线性筛素数。
  8. 当 n ≤ 1 0 9 n\leq 10^9 n≤109时,可以接受的最大的时间复杂度为 O ( n ) O(\sqrt{n}) O(n ),那么可以考虑的算法有:判断质数。
  9. 当 n ≤ 1 0 18 n\leq 10^{18} n≤1018时,可以接受的最大的时间复杂为 O ( l o g n ) O(logn) O(logn),那么可以考虑的算法有:最大公约数。

(二)

计算时间复杂度的小技巧,有

  • 看循环,有几重循环就是n的几次方的时间复杂度。
  • 并查集的时间复杂度是 O ( n l o g n ) O(nlogn) O(nlogn)。
  • 动态规划问题的计算量 = 状态的数量 * 状态转移的计算量。

2 模板

暂无。。。

3 工程化

暂无。。。

相关推荐
小刘|21 分钟前
《Java 实现希尔排序:原理剖析与代码详解》
java·算法·排序算法
jjyangyou26 分钟前
物联网核心安全系列——物联网安全需求
物联网·算法·安全·嵌入式·产品经理·硬件·产品设计
van叶~43 分钟前
算法妙妙屋-------1.递归的深邃回响:二叉树的奇妙剪枝
c++·算法
简简单单做算法44 分钟前
基于Retinex算法的图像去雾matlab仿真
算法·matlab·图像去雾·retinex
云卓SKYDROID1 小时前
除草机器人算法以及技术详解!
算法·机器人·科普·高科技·云卓科技·算法技术
半盏茶香1 小时前
【C语言】分支和循环详解(下)猜数字游戏
c语言·开发语言·c++·算法·游戏
徐子童1 小时前
双指针算法习题解答
算法
想要打 Acm 的小周同学呀2 小时前
LRU缓存算法
java·算法·缓存
劲夫学编程3 小时前
leetcode:杨辉三角
算法·leetcode·职场和发展
毕竟秋山澪3 小时前
孤岛的总面积(Dfs C#
算法·深度优先