当前位置: 首页 > article >正文

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

目录

  • 1 基础知识
  • 2 模板
  • 3 工程化

1 基础知识

(一)
由数据范围反推算法。

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

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

  1. n ≤ 30 n\leq 30 n30时,指数级别,可以考虑的算法有:dfs+剪枝,状态压缩dp。
  2. n ≤ 1 0 2 n \leq 10^2 n102时,可以接受的最大的时间复杂度为 O ( n 3 ) O(n^3) O(n3),那么可以考虑的算法有:floyd,dp。
  3. n ≤ 1 0 3 n\leq 10^3 n103时,可以接受的最大的时间复杂度为 O ( n 2 l o g n ) O(n^2logn) O(n2logn),那么可以考虑的算法有:dp,二分。
  4. n ≤ 1 0 4 n \leq 10^4 n104时,可以接受的最大的时间复杂度为 O ( n n ) O(n\sqrt{n}) O(nn ),那么可以考虑的算法有:块状链表。
  5. n ≤ 1 0 5 n\leq 10^5 n105时,可以接受的最大的时间复杂度为 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 n106时,可以接受的最大的时间复杂度为常数较小的 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 n107时,可以接受的最大的时间复杂度为 O ( n ) O(n) O(n),那么可以考虑的算法有:双指针扫描,kmp,AC自动机,线性筛素数。
  8. n ≤ 1 0 9 n\leq 10^9 n109时,可以接受的最大的时间复杂度为 O ( n ) O(\sqrt{n}) O(n ),那么可以考虑的算法有:判断质数。
  9. n ≤ 1 0 18 n\leq 10^{18} n1018时,可以接受的最大的时间复杂为 O ( l o g n ) O(logn) O(logn),那么可以考虑的算法有:最大公约数。

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

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

2 模板

暂无。。。

3 工程化

暂无。。。


http://www.kler.cn/news/159629.html

相关文章:

  • MFC对话框集成OSG无法响应键盘事件
  • 使用Pytorch从零开始实现BERT
  • python爬虫-某公开数据网站实例小记
  • vue中el-upload结合vuedraggable实现图片的上传、排序、删除以及预览等功能
  • 2023-12-01 AndroidR 系统在root目录下新建文件夹和创建链接,编译的时候需要修改sepolicy权限
  • 创建腾讯云存储桶---上传图片--使用cos-sdk完成上传
  • 简介Kadane算法及相关的普通动态规划
  • RepidJson将内容格式化后写入文件
  • 【OpenSSH升级】升级后证书认证登录突然失效
  • C语言能判断一个变量是int还是float吗?
  • 若依框架 前台自己获取登录用户信息
  • 矩阵处理—转圈打印矩阵
  • HomeAssistant如何添加HACS插件实现公网控制米家与HomeKit等智能家居
  • Redis的基本数据类型及常用命令
  • Codeforces Round 913 (Div. 3) A~E(F,G更新中)
  • ES6迭代器
  • Elasticsearch一些函数查询
  • 【头歌系统数据库实验】实验4 MySQL单表查询
  • HarmonyOS学习--TypeScript语言学习(三)
  • 图片点击放大
  • go基础语法10问(2)
  • WPF Live Charts2 自学笔记
  • 20、pytest中的参数化
  • 213. 打家劫舍 II --力扣 --JAVA
  • 华为云obs在java中的使用
  • 应用层自定义协议
  • Jmeter测试移动接口性能 —— 压测
  • MySQL性能调优-2-实际优化案例
  • Redis高效缓存:加速应用性能的利器
  • 反序列化漏洞详解(二)