《算法图解》笔记——第一章

本文探讨了简单查找与二分查找的区别,指出二分查找在100以内的数字能在7次内找到目标,而简单查找则需更多尝试。通过对比线性时间和对数时间,介绍了大O表示法的概念,解释了算法运行时间的增速如何度量。

1.简单查找

简单查找,更准确的说是傻找,每次猜测都只能排除一个数字。

2.二分查找

使用二分查找
使用二分查找时,在100以内的数字,在7次之内都能猜到,因为每次猜测都将排除很多数字。

本书所讨论的运行时间,log指的都是log2。
如果列表包含1024个元素,你最多需要检查10个元素,因为log1024 = 10

# python while循环版
def binary_search(list, item):
    low = 0
    hight = len(list) - 1#减了一个,多的在右边。不减多的一个在左边
    while low <= hight:
        mid = (low + hight)//2  # 双斜线表示取整
        guess = list[mid]       # guess表示我们猜测mid位置即为我们要查找的元素
        if(guess == item):      # 如果我们猜中,返回下表
            return mid
        if(guess < item):       # 如果猜测的值比较小 那么我们从新的将区间定位的较大的区间
            low = mid + 1
        else:
            hight = mid - 1     # 如果猜测的时间比较大,我们把新的区间定位到较小的区间

    return None                 # 未能匹配到值

#test
my_list = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
print(binary_search(my_list, 7))

1.3运行时间

  • 线性时间:需要猜测的次数与列表长度相同,这被称为线性时间(linear time)
  • 二分查找的运行时间为对数时间(或log时间)
    在这里插入图片描述

1.4大O表示法

大O表示法指出了算法的速度有多快。仅知道算法需要多长时间才能运行完毕还不够,还需要知道运行时间如何随着列表增长而增加。大O表示法指的并非以秒为单位的速度,大O表示法能够比较操作数,指出了算法运行时间的增速。

在这里插入图片描述
4x4的网格需要折叠4次就能得到16个格子。
而简单算法需要16次才能完成。

大O表示法指出了最糟情况下的运行时间为O(n),简单查找的运行时间不可能超过O(n)。

1.5一些常见的大O运行时间

在这里插入图片描述
在这里插入图片描述

1.6旅行商

在这里插入图片描述
推而广之,涉及n个城市时,需要执行n!次操作才能计算出结果

1.7小结

  • 二分查找比简单查找快得多
  • O(log n)比O(n)快得多
  • 算法的运行时间并不以秒为单位
  • 算法的运行时间是从其增速的角度度量的
  • 算法运行时间用大O表示法表示
下载方式:https://pan.quark.cn/s/c9b9b647468b ### 初级JSP程序设计教程核心内容解析#### 一、JSP基础概述JSP(JavaServer Pages)是由Sun Microsystems公司创建的一种动态网页技术规范,主要应用于构建动态网站及Web应用。JSP技术使得开发者能够将动态数据与静态HTML文档整合,从而实现网页内容的灵活性和可变性。##### JSP的显著特性:1. **动态与静态内容的分离**:JSP技术支持将动态数据(例如数据库查询结果、实时时间等)嵌入到静态HTML文档中。这种设计方法增强了网页的适应性和可维护性。2. **易用性**:开发者可以利用常规的HTML编辑工具来编写静态部分,并通过简化的标签技术将动态内容集成到页面中。3. **跨平台兼容性**:基于Java平台的JSP具有优良的跨操作系统运行能力,能够在多种不同的系统环境中稳定工作。4. **强大的后台支持**:JSP能够通过JavaBean组件访问后端数据库及其他资源,以实现复杂的数据处理逻辑。5. **执行效率高**:JSP页面在初次被请求时会被转换为Servlet,随后的请求可以直接执行编译后的Servlet代码,从而提升了服务响应的效率。#### 二、JSP指令的运用JSP指令用于设定整个JSP页面的行为规范。这些指令通常放置在页面的顶部,向JSP容器提供处理页面的相关指导信息。##### 主要的指令类型:1. **Page指令**: - **语法结构**:`<%@ page attribute="value" %>` - **功能**:定义整个JSP页面的运行特性,如设定页面编码格式、错误处理机制等。 - **实例**: ...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值