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

做网站需要公司授权嘛python3 网站开发入门

做网站需要公司授权嘛,python3 网站开发入门,wordpress dux 增强,北京门户网站建设公司文章目录 前言一、什么是数据结构二、什么是算法三、算法复杂度1. 时间复杂度① 时间复杂度的定义② 大O的渐进表示法 总结 前言 数据结构简单介绍、算法简单介绍、算法复杂度、时间复杂度等的介绍 一、什么是数据结构 数据结构是计算机存储,组织数据结构的方式&…

文章目录

  • 前言
  • 一、什么是数据结构
  • 二、什么是算法
  • 三、算法复杂度
    • 1. 时间复杂度
      • ① 时间复杂度的定义
      • ② 大O的渐进表示法
  • 总结


前言

数据结构简单介绍、算法简单介绍、算法复杂度、时间复杂度等的介绍

一、什么是数据结构

数据结构是计算机存储,组织数据结构的方式,指相互之间存在一种或多种特定关系的数据元素的集合。

二、什么是算法

算法: 简单来说算法就是一系列的计算步骤,用来将输入数据转化成输出结果。

三、算法复杂度

衡量一个算法的好坏,一般是从时间和空间两个维度来衡量的。即时间复杂度和空间复杂度

  • 时间复杂度主要衡量一个算法的运行快慢
  • 空间复杂度主要衡量一个算法运行所需要的额外空间
  • 随着技术发展,计算机存储容量变得非常大,已经不是非常关注空间复杂度,而是更关注时间复杂度

1. 时间复杂度

① 时间复杂度的定义

  • 算法的时间复杂度是一个函数(函数式),一个算法执行所耗费的时间,理论上是不能算出来的,只有运行程序才能知道。
  • 但是一个算法所花费的时间与其中语句的执行次数正比例
  • 所以算法中的基本操作的执行次数,为算法的时间复杂度。

② 大O的渐进表示法

实际计算时间复杂度,不计算精确的执行次数,只需要计算大概执行次数(量级或阶数),我们用大O的渐进表示法。

  • 时间复杂度: O(N),习惯用N表示

1、用常数1取代运行时间中的所有加法常数。

int main()
{int count = 0;int M = 10;while (M--){++count;}printf("%d\n", count);
}
  • 上述代码执行 M 次 相当于是 10 次, 也就是函数执行的量级是10(常数级),常数级用O(1)表示

2、在修改后的运行次数函数中,只保留最高阶项。
3、如果最高阶项存在且不是1,则去除与这个项目相乘的常数。得到的结果就是大O阶。

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);
}
  • 上述代码执行 (2 * N + M)次, 只保留高阶项
  • 高阶项存在且不是1,去除常数。
  • (2 * N)次,所以Func2的时间复杂度是: O(N)。

有些算法的时间复杂度存在最好、最坏和平均的情况。
在实际中一般情况关注的是算法的最坏运行情况

实例如下:

实例1:

void Func4(int N)
{int count = 0;for (int k = 0; k < 100; ++ k){++count;}printf("%d\n", count);
}
  • 上述Func4的时间复杂度是:O(1)

实例2:

const char * strchr ( const char * str, int character );
  • 上述strchr 的时间复杂度是O(N)
  • 按最坏的情况算

实例3:

void BubbleSort(int* a, int n)
{assert(a);for (size_t end = n; end > 1; --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;}
}
  • 上述BubbleSort的时间复杂度
  • 若数组本来就有序(最好情况),则时间复杂度为O(N)
  • 若数组无序(最坏情况),则时间复杂度为O(N^2)
  • 时间复杂度为O(N^2)

实例4:

int BinarySearch(int* a, int n, int x)
{assert(a);int begin = 0;int end = n-1;while (begin <= end){int mid = begin + ((end-begin) / 2);if (a[mid] < x)begin = mid+1;else if (a[mid] > x)end = mid-1;elsereturn mid;}return -1;
}
  • 上述二分法时间复杂度为 O(logN) 这里的log是以2为底

实例5:

long long Fac(size_t N)
{if(0 == N)return 1;return Fac(N-1)*N;
}
  • 上述代码Fac(N) , Fac(N-1), Fac(N-2), …F(0), 共N+1次,所以时间复杂度是O(N)

实例6:

long long Fib(size_t N)
{if(N < 3)return 1;return Fib(N-1) + Fib(N-2);
}
  • 上述代码调用会调 2 ^ N次,所以时间复杂度为 O(2 ^ N)

实例7

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);
}
  • 上述Func3的时间复杂度是O(M + N)
  • 若 M >> N, 则时间复杂度为 O(M)
  • 若 N >> M, 则时间复杂度为 O(N)
  • 若 M = N, 则时间复杂度为 O(M)或O(N)
  • 若没有说明,时间复杂度为O(M + N)

总结

数据结构简单介绍、算法简单介绍、算法复杂度、时间复杂度等的介绍

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

相关文章:

  • 访问网站的过程百度关键词点击价格查询
  • 网站根目录在哪wordpress青岛君哲网站建设公司怎么样
  • 成都网站建设网站网站建设与管理 管理课程
  • 北京网站建设营销网站名称格式
  • 云趣在线企业网站建设南昌房产网
  • 东营网站建设设计网站建设设计公司
  • 网站推广策划案例重庆公司注册服务
  • 证券投资网站做哪些内容设计优秀的网站推荐
  • 兰州专业做网站的公司哪家好烟台H5高端网站建设
  • 一个网站的建设需要什么手续网站uv pv
  • 未备案网站 怎么处理一般通过东方众
  • 靖宇东兴自助建站wordpress留言板源码
  • 网站规划内容方案奉贤广州网站建设
  • 百度搜索网站下方描述百度网盘怎么用
  • 网站建设服务器费用网站建设淘宝店铺模板
  • 广州网站快速制作js做网站预览效果
  • 创业投资平台网站推广优化外包公司哪家好
  • 国外网站 图片免费seo优化
  • 校园网站建设成本邢台123信息最新招聘信息
  • 做网站时怎样图片上传怎么才能让图片不变形有什么插件吗seo确定关键词
  • 网站服务器租赁需要什么手续手机wap网站怎么做
  • 网站建设及运维方案企业管理培训课程心得体会
  • 网站建设报价网站建设报价单郑州营销型网站设计
  • 网站建设需求分析报告郑州企业免费建站
  • 营销网站竞品分析报告网站建设色
  • 网站建设资金投入企业管理咨询培训
  • wordpress 用什么语言seo综合查询是什么
  • 做网站前端设计需要哪些证书宿迁交通工程建设有限公司网站
  • 网站建设广告费 科目江西网站建设推广
  • wordpress网站会员太多wordpress附带默认脚本