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

网站名是什么discuz做企业网站

网站名是什么,discuz做企业网站,软文素材库,网络营销的效果是什么目录 时间复杂性 ⼤O的渐进表⽰法 时间复杂性 定义:在计算机科学中,算法的时间复杂度是⼀个函数式T(N),它定量描述了该算法的运⾏时间。 时间复杂度是衡量程序的时间效率,那么为什么不去计算程序的运⾏时间呢? 1.…

目录

时间复杂性

⼤O的渐进表⽰法 


时间复杂性

定义:在计算机科学中,算法的时间复杂度是⼀个函数式T(N),它定量描述了该算法的运⾏时间。

 

时间复杂度是衡量程序的时间效率,那么为什么不去计算程序的运⾏时间呢? 

1. 因为程序运⾏时间和编译环境和运⾏机器的配置都有关系,⽐如同⼀个算法程序,⽤⼀个⽼编译 器进⾏编译和新编译器编译,在同样机器下运⾏时间不同。

2. 同⼀个算法程序,⽤⼀个⽼低配置机器和新⾼配置机器,运⾏时间也不同。

3. 并且时间只能程序写好后测试,不能写程序前通过理论思想计算评估。 

所以时间复杂度只能粗估,不能用来精确的进行计算 

我们看一个实例:

// 请计算⼀下Func1中++count语句总共执⾏了多少 次?

void Func1(int N)
{
    int count = 0;
    for (int i = 0; i < N; ++i)
    {
        for (int j = 0; j < N; ++j)
        {
            ++count;
        }
    }
    for (int k = 0; k < 2 * N; ++k)
    {
        ++count;
    }
    int M = 10;
    while (M--)
    {
        ++count;
    }
}

 

 时间复杂度计算公式=每条语句的运行时间(不确定)*语句运行次数(确定)

根据上述公式

我们可以得出示例:

                T(N)=N^2+2N+10

在N取不同值时,时间复杂度的粗估值也不同

时间复杂的经典实例:

实例1

void Func2(int N)
{
int count = 0;
for (int k = 0; k < 2 * N ; ++ k)
{
++count;
}
int M = 10;
while (M--)
{
++count;
}
printf("%d\n", count);
}

 



实例二

void Func3(int N, int M)
{
int count = 0;
for (int k = 0; k < M; ++ k)
{
++count;
}
for (int k = 0; k < N ; ++
k)
{
++count;
}
printf("%d\n", count);
}

 


实例3:

void Func4(int N)
{
int count = 0;
for (int k = 0; k < 100; ++ k)
{
++count;
}
printf("%d\n", count);
}


实例4:

const char * strchr ( const char
* str, int character)
{
const char* p_begin = s;
while (*p_begin != character)
{
if (*p_begin == '\0')
return NULL;
p_begin++;
}
return p_begin;
}

 


 

实例5:

void BubbleSort(int* a, int n)
{
assert(a);
for (size_t end = n; end > 0; --end)
{
int exchange = 0;
for (size_t i = 1; i < end; ++i)
{
if (a[i-1] > a[i])
{
Swap(&a[i-1], &a[i]);
exchange = 1;
}
}
if (exchange == 0)
break;
}
}

 


 

实例6

void func5(int n)
{
int cnt = 1;
while (cnt < n)
{
cnt *= 2;
}
}

 


 

实例7


 


 

⼤O的渐进表⽰法 

规则:

1.时间复杂度函数式T(N)中,只保留最⾼阶项,去掉那些低阶项,因为当N不断变⼤时, 低阶项对结果影响越来越⼩,当N⽆穷⼤时,就可以忽略不计了。

2. 如果最⾼阶项存在且不是1,则去除这个项⽬的常数系数,因为当N不断变⼤,这个系数 对结果影响越来越⼩,当N⽆穷⼤时,就可以忽略不计了。

3. T(N)中如果没有N相关的项⽬,只有常数项,⽤常数1取代所有加法常数。

各位不妨自行根据规则来对将T(N)改成O(N)

答案:FUNT1:O(N)

FUNT2:O(N)

FUNT3:O(1)

FUNT4:

1.O(1)

2.O(N)

3.O(N)

FUNT5:

1.O(1) 

2.O(N^2)

FUNT6:O(logn)

FUNT7:O(n) 

http://www.yayakq.cn/news/990073/

相关文章:

  • 做招工的网站排名全国城乡和住房建设厅查询网
  • 网站 服务报价怎么增加网站首页权重
  • 华为模板建站网站上传权限问题
  • 织梦网站模板安装教程网站中留言板怎么做
  • 网站流量如何做制作企业网站的新闻显示
  • 沈阳网站页面设计公司青海网站建设的企业
  • 网站建设费用怎么算wordpress迁移后媒体库丢失
  • 网站编辑应该怎么做深圳龙岗发布通告
  • 重庆网站搭建方案wordpress点击图片直接相册浏览器
  • 怎么查看自己网站有没有被百度收录wordpress禁止访问后台
  • 建设银行网站背景图片北京市文化局政务网站建设项目
  • 北京网站建设app高要市建设局网站
  • 小城镇建设网站并阐述观点ps免费素材网站有哪些
  • 专业购物网站建设报价百度关键词优化软件怎么样
  • 网站改版了外贸网站模板外贸网站建设
  • 广州知名网站建设有哪些杭州百度开户
  • 伪类网站seo网站怎么搭建
  • 已备案网站更换域名grace8WordPress主题
  • 浙江荣盛建设集团网站学技术的培训学校
  • 镇江网站建设活动方案西部数据网站备案流程
  • 网站icp备案信息是什么意思企业年报查询
  • 教育类的网站案例软件开发工时费一般是多少
  • 大连网站建设选高合科技宁波高新区做网站的公司
  • 网站建设金手指排名稳定暖暖 免费 视频 在线观看1
  • 柳州市网站建设公司遵化手机网站设计
  • 网站域名收费标准天猫网站做的比京东好
  • 自助建站系统官方版龙岩抖音seo搜索排名
  • dede做漫画网站的案例通辽市北京网站建设
  • 网站开发很难么云服务器使用教程
  • 交易猫钓鱼网站制作教学企业官网登录