时空复杂度分析总结

这篇博客总结了时空复杂度分析,包括有循环情况下的单重和多重循环的计算,无循环时的时间复杂度为O(1)。讨论了在实际运行中为何会出现WA(错误答案)和TLE(超时)的区别,并强调了计算最坏情况的重要性,通过举例说明如何判断程序在极限数据范围下是否会超时。
摘要由CSDN通过智能技术生成

一.有循环

    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
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值