一.有循环
1.单重循环 直接看循环次数
2.多重循环 直接把每重循环次数乘起来
二.无循环 o(1)
三.1秒测评机 会执行 10^9次运算
四.为什么是WA而不是TLE?
1.超时了,一直跑都没跑出来 WA
2.超时了,但是跑出来了和数据是匹配的 TLE
五.为什么要算最坏的情况?
基本上每个题都有一个极限的数据范围。如果最坏的情况都不会超时说明程序一定不会超时。
例 1 洛谷p2249
#include<iostream>
using namespace std;
int main()
{
int n, m;
cin >> n >> m;
for(int i = 1; i <= n; i ++) cin >> a[i];//读入
// 1.严格单调递增1 2 3 4 5 6 2.非严格单调递增的 1 1 2 2 3 5 6
// 处理m个询问
// 暴力时间复杂度是O(nm) n=10^6 m=10^5 nm = 10^11 1s 10^9 所以O(nm)一定会超时
while(m --) //外层的O(m)是必定的,优化不了 所以我们考虑优化循环里面的操作。
{
//查找一个数出现的第一个下标 暴力O(n