常见算法的时间复杂度
规定n是数组的长度/树或图的节点数
 二分查找:O(logn)
 双指针/滑动窗口:O(n)
 DFS/BFS:O(n)
 构建前缀和:O(n)
 查找前缀和:O(1)
 一维动态规划:O(n)
 二维动态规划:O(n^2)
 回溯:O(2^n)/O(n!)
 
下面重点来辣
数据范围反推时间复杂度
数据范围:n~100
O(n!)/O(2^n)的时间复杂度
 应该考虑回溯或任何蛮力式的递归算法
 如:全排列、组合、N皇后
 
数据范围:n~1,000
O(n^2)的时间复杂度
 通常涉及双重循环,内层循环可能涉及双指针、dp等等

 如:三数之和、最接近的三数之和
 
数据范围:n~100,000
O(logn)/O(n)/O(nlogn)的时间复杂度
 双重循环无法通过,但可以接受直接遍历,很多贪心/双指针的问题
 如:两数之和、盛最多水的容器、救生艇
 
数据范围:n~1,000,000
O(1)/O(logn)的时间复杂度
 涉及二分查找或数学解法
如:数字1的个数、猜数字大小
 

程序运行时间和什么有关
数据量大小
 算法的好坏