大O记法

C++的大O记法是算法的时间复杂度表达公式。简单的说O记法可以告诉你一个算法耗费的时间长度同算法所处理的数据量大小的关系。 大O记法只是一个概念性的或定性的记号,不能通过它来真正计算一个算法所耗费的精确时长。
O(1) 算法只花费一个 单位 时间长度的时间。同所处理的数据量大小没有关系(常量时间)。
       “ 一个 单位 时间长度”没有定义为1秒,1天,还是1微妙,完全随意指定。大约同处理一个数据项的时长相同。
       考虑一个数组,按照数组下标的到一个元素的引用
       int arr[100];
       int x = arr[88]; //这个算法就是O(1)的
        O(1)是最爽的,哪怕有1亿条数据还是1条数据,算法所费时间是常量。
 
O(N)  算法只花费N个 单位 时间长度的时间。数据量大小同算法所花费时长成正比例
       考虑一个list链表
       list.remove( 88 ); //把第88个元素删除。 这个算法就是O(N)的
        O(N)是最不爽的,假设有1亿条数据,算法就要花费1亿个时间单位的时长。
 
O(logN)  算法只花费logN个 单位 时间长度的时间。
          logN是取对数,可以简单的理解为取以2为底数,N的对数。例如log65536=16 (因为2^16=65536)
         对数是把一个天文数字般的整数映射成一个小小的整数的数学工具。
         考虑一个已排序的数组,用“折半法”查找,算法的时间特性就是 O(logN)的。
         O(log(一个亿))约等于19个单位时间的时长。
      O(logN)也不一定是以2为底的,也可能是以3为底的,这都无所谓。
 
算法在应用于局部小数据量时,可能因为内存的申请,释放,初始化等原因,观察者发现不符合大O记法表示的特性。
但是在长期的运行,经过大数据量的考验后,那些干扰因素逐渐沦为次要因素, 观察者可以发现算法的却符合某种自己固有的时间特性。
 
后注:O记有组织罪案及三合会调查科,同 O记法没有关系。
嗨!对于Docker零基础入门精通,我可以给你一些指导。首先,让我们从Docker的基础开始。 1. 安装Docker:首先,你需要在你的机器上安装Docker。你可以去Docker官方网站上下载适合你操作系统的版本,并按照官方文档中的说明进行安装。 2. Docker镜像和容器:Docker使用镜像和容器来管理应用程序和服务。镜像是一个只读的模板,它包含了构建应用程序所需的所有文件和配置。容器是基于镜像创建的运行实例,它可以被启动、停止、删除等操作。 3. Dockerfile:Dockerfile是一个包含了一系列命令的文本文件,用于自动化构建Docker镜像。通过编写Dockerfile,你可以定义构建镜像所需的环境、依赖和配置。 4. Docker命令:学习一些常用的Docker命令是非常重要的。这些命令可以帮助你管理镜像、容器、网络等。一些常用的命令包括:`docker run`(运行容器),`docker build`(构建镜像),`docker stop`(停止容器)等。你可以通过查阅Docker官方文档来了解更多命令的详细用法。 5. Docker Compose:Docker Compose是一个用于定义和管理多个Docker容器的工具。它使用YAML文件来配置应用程序的服务、网络、卷等。通过使用Docker Compose,你可以轻松地启动、停止和管理多个容器。 6. Docker网络:Docker提供了不同类型的网络,用于连接和通信容器。你可以使用默认的桥接网络,也可以创建自定义网络。此外,Docker还支持外部网络和容器之间的链接。 7. Docker卷:Docker卷是用于持久化数据的机制。通过使用卷,你可以将容器内的数据存储到宿主机上的特定位置,从而实现数据的持久化和共享。 这些是Docker入门的一些基本概念和工具。一旦你熟悉了这些基础知识,你可以进一步学习Docker的高级特性,如Docker Swarm(用于集群管理)、Docker Registry(用于镜像存储和分发)等。 希望这些信息对你有所帮助!如果你有更具体的问题,我会尽力回答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值