这个程序的时间复杂度是多少

chuifeng78 2011-03-09 10:33:43
RT

#include<iostream>
#include<vector>
using namespace std;
template<class T>
int search(vector<T> &x)
{
vector<T>::iterator itx=x.begin(),ity=x.end()-1;
T s1=*itx,s2=*ity,s=1;
while(itx!=x.end()-1 || ity!=x.begin())
{
if(s1==s2)
{
s++;
itx++;
ity--;
s1+=*itx;
s2+=*ity;
continue;
}
if(s1<s2)
{
itx++;
s1+=*itx;
continue;
}
if(s1>s2)
{
ity--;
s2+=*ity;
continue;
}
}
return s;
}
int main()
{
vector<int> x;
int i,y,n;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&y);
x.push_back(y);
}
printf("%d\n",search(x));
return 0;
}

...全文
61 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
飞天御剑流 2011-03-09
  • 打赏
  • 举报
回复
这个算法的时间复杂度的平均执行时间和最坏情况的数量级都是θ(n)的
ww884203 2011-03-09
  • 打赏
  • 举报
回复
O(n)
healer_kx 2011-03-09
  • 打赏
  • 举报
回复
o(n)
sayyoume8220202 2011-03-09
  • 打赏
  • 举报
回复
按照循环的次数来计算把

64,639

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧