《船说:算法与数据结构》是B站上由胡船长主讲的一门课程,致力于帮助大学生深入理解和掌握C/C++/JAVA/Python等编程语言中的数据结构知识。这门课程不仅涵盖了基础的数据结构类型,如数组、链表、栈、队列,还深入探讨了树形结构、图论、哈希表以及排序和查找算法等核心主题。通过学习这些内容,学生可以提升编程能力,为解决复杂问题打下坚实基础。 在提供的压缩包文件"胡船长,B 站《船说:算法与数据结构》课程讲义和代码.zip"中,我们可以找到一系列的学习资源,包括讲义和实际的代码示例。这些资料对于初学者和进阶者都非常有价值,因为理论与实践的结合是理解数据结构的关键。 让我们来详细了解一下数据结构这个概念。数据结构是计算机科学中一个重要的基础学科,它研究如何在计算机中组织和存储数据,以便高效地进行访问和修改。数据结构的选择直接影响到程序的效率和设计。常见的数据结构有以下几种: 1. **数组**:最基础的数据结构,它是一个元素类型相同的集合,可以通过索引快速访问任一元素。但是插入和删除操作通常比较低效。 2. **链表**:每个节点包含数据和指向下一个节点的引用,适合频繁的插入和删除操作。根据链表的指向,可分为单向链表和双向链表。 3. **栈**:遵循“后进先出”(LIFO)原则的数据结构,常用于表达式求值、递归调用等场景。 4. **队列**:遵循“先进先出”(FIFO)原则,常用于任务调度、消息传递等场景。 5. **树**:一种非线性的数据结构,每个节点可有零个或多个子节点,如二叉树、平衡树(AVL树、红黑树)等,广泛应用于搜索和排序问题。 6. **图**:由节点(顶点)和边组成,表示对象间的关系,可用于网络路由、社交网络分析等问题。 7. **哈希表**:通过哈希函数将数据映射到固定大小的桶中,实现快速查找、插入和删除,但可能产生冲突问题。 8. **堆**:一种特殊的树形数据结构,满足堆性质(最大堆或最小堆),常用于优先队列和优化算法(如堆排序)。 9. **排序算法**:如冒泡排序、选择排序、插入排序、快速排序、归并排序等,用于对数据进行升序或降序排列。 10. **查找算法**:如线性查找、二分查找、哈希查找等,用于在数据中寻找特定元素。 学习这些数据结构的同时,配合实际的代码示例尤为重要。胡船长的课程讲义和代码将帮助学生深入理解每种数据结构的实现细节和应用场景。通过阅读和运行代码,学生可以亲手实践,增强对数据结构的理解,并能提高编程技能。 《船长的算法与数据结构》课程提供了丰富的学习资源,不仅包括理论知识,还有实践案例。对于想要提升编程能力和算法水平的学子来说,这是一个不可多得的宝藏。利用这些资源,相信你将在数据结构的世界里游刃有余,为未来的技术之路铺就坚实的基石。
2024-08-10 10:12:06 108.48MB 数据结构
1
​“讯飞星火认知大模型”是科大讯飞发布的产品,具有7大核心能力,即文本生成、语言理解、知识问答、逻辑推理、数学能力、代码能力、多模态能力。 ​实现原理 1、申请星火大模型的 APP_ID 等相关信息 2、通过使用的大模型版本,以及当前的时间,结合 申请星火大模型的 APP_ID 等相关信息,生成需要的 URL 3、通过对应的 json 数据格式,websocket 进行建立连接请求 4、这里是流式返回,对应解析数据格式,得到返回的信息 5、返回的关键信息结构,有些类似 gpt 的数据格式,用过的话,使用起来会很快 注意事项 1、注意 code 返回码,不同的返回码可以进行不同处理,避免产生意想不到的问题 2、注意 sid 的区分,如果上一次返回没有结束,关闭连接后,重新发起新的访问,可能会同时接收到上一次的未结束的数据流,和当次的数据流;如果不想接收到,注意通过 sid 进行区分; 3、注意在 LLMConfig 配置你的 APP_ID 等相关信息
2024-08-09 14:16:16 1.09MB unity IFly
1
mybatis代码自动生成器,在generatorConfig.xml中配置好数据库连接和表名,进入解压后的目录运行如下命令:java -jar mybatis-generator-core-1.3.2.jar -configfile generatorConfig.xml -overwrite 即可自动生成对应的dao、mapper、pojo
2024-08-09 14:05:07 4.32MB mybatis generator
1
金蝶Amdc资源包,内涵X86-64和Arm64
2024-08-09 12:17:28 139.26MB Redis
1
《手机安全和可信应用开发指南:TrustZone与OP-TEE技术详解》这本书是关于网络空间安全技术的一本专著,由帅峰云、黄腾、宋洋三位作者编著。书中详细介绍了如何利用TrustZone技术和OP-TEE来保护智能手机、智能电视以及物联网(IoT)等领域的数据安全。 书中探讨了当前系统存在的安全问题,包括隐私泄露、恶意软件攻击等,这些威胁都源于系统缺乏有效隔离和保护机制。可信执行环境(Trusted Execution Environment, TEE)正是为了解决这些问题而设计的。TEE可以在同一硬件平台上提供一个安全的区域,使得敏感操作和数据处理能在受保护的环境中进行,防止未授权访问和篡改。 在介绍TEE解决方案时,书中特别提到了在智能手机领域的TrustZone应用,如通过硬件隔离来确保支付应用、生物识别数据等的安全。此外,还讨论了智能电视领域和IoT领域的TEE实现,强调了这些领域的安全需求和挑战,以及TEE如何满足这些需求。 TrustZone是ARM公司提供的一种硬件级别的安全技术,通过硬件划分安全世界和普通世界,确保安全世界的执行不受非安全世界的影响。书中深入解析了ARMv7和ARMv8架构下的TrustZone技术,包括硬件框架、安全状态位扩展、地址空间控制、内存适配器、保护控制器、中断控制器等组件的功能,以及如何实现资源隔离,如中断源、内存和外围设备的隔离。 ARM可信固件(ARM Trusted Firmware, ATF)在TrustZone中扮演着重要角色,它是启动流程中的关键组件,负责初始化硬件并启动安全操作系统。书中还讲解了如何构建和运行OP-TEE(Open-Source Trusted Execution Environment)的环境,包括获取源代码、编译工具链、配置QEMU模拟器等步骤,并提供了运行示例代码的详细指导。 在系统集成篇中,作者详述了QEMU运行OP-TEE的启动过程,包括各阶段的镜像加载、内核启动和rootfs挂载等。同时,书中还详细分析了安全引导功能和ATF的启动流程,以及OP-TEE OS自身的启动步骤,包括内核初始化和服务启动等。 OP-TEE在REE(Rich Execution Environment)侧的上层软件,如libteec库和tee_supplicant守护进程,也在书中有所阐述。libteec库提供了与TEE交互的接口,而tee_supplicant则作为桥梁,处理REE与TEE之间的通信请求。 这本书为读者提供了一套全面的TrustZone和OP-TEE技术指南,适合对移动设备和物联网安全感兴趣的开发者、研究人员和安全专业人员阅读,帮助他们理解和实践基于硬件的信任根的安全应用开发。
2024-08-09 10:06:52 18.58MB
1
第一种方法可以实现我当前的需求,通过连接不同的字符串来连接不同的数据库。暂时只连接了mysql,sqlserver,oracle,access。对于access,因为它创建表的SQL语句不太兼容标准SQL语句,需要做一些处理,这里暂时不说。第二种方法只能针对于mysql数据库的连接,不过用这种方法不用安装MyODBC服务器程序。 不管用哪种方法,首先需要安装Mysql数据库,安装方法请看“mysql安装及一些注意点”。最好安装一个Navicat for mysql,方便操作mysql数据库。下面分别说下这两种方法: (一)通过ADO连接MySql数据库 1、通过ADO连接MySql数据库,首先
2024-08-08 17:37:47 85KB
1
生产计划和执行 SAP食品行业 ERP一体化解决方案能管理多步骤制造流程。一个主要的特点是完全集成了生产过程中和生产后的质量管理,以及样品管理。支持整个生产步骤中的可追溯性,基于特定特征和过期日期的自动批次确定在制造执行期间得以执行。 行业困扰 来自零售/自有品牌的日渐增加所导致的竞争压力 客户需求的快速变化 季节性的变化需求 由于产品高复杂性带来的生产计划和执行的管理困难 基于一定时期的收益和成本的透明度 分段复杂的生产环境 整个生产过程中的可追溯性 企业收益 改进食品生产中的透明度 灵活响应波动需求 实现更高的需求准确度 通过高效生产流程减少运营成本并增加效率 无缝计算并监控生产成本 解决方案 分段生产 分段计划 流程内和流程后质量管理 半成品的加工和还原 通过用户友好界面获得车间数据 获得可追溯性数据 分段成本分析 分段统计 辅助处理 辅助处理计划 实例管理 流程后质量管理 获得可追溯性数据 生产订单成本 打印重量、批次、日期等标签 生产计划 创建预测 短期和中期计划 能力均衡 能力检查 按库存处理
2024-08-08 14:07:21 4.06MB
1
1、资源内容:基于Matlab实现跳频通信基本原理仿真:跳频的发射、接收和跳频图案生成(源码+说明文档).rar 2、适用人群:计算机,电子信息工程、数学等专业的学习者,作为“参考资料”参考学习使用。 3、解压说明:本资源需要电脑端使用WinRAR、7zip等解压工具进行解压,没有解压工具的自行百度下载即可。 4、免责声明:本资源作为“参考资料”而不是“定制需求”,代码只能作为参考,不能完全复制照搬。不一定能够满足所有人的需求,需要有一定的基础能够看懂代码,能够自行调试代码并解决报错,能够自行添加功能修改代码。由于作者大厂工作较忙,不提供答疑服务,如不存在资源缺失问题概不负责,谢谢理解。
2024-08-07 13:25:07 957KB matlab 网络 网络
1
输入参数p : 奇素数deg:正整数(默认值 = 1) 输出是一个 (p^deg+1) by (p^deg+1)/2 矩阵 E 当 deg > 1 时,需要通讯工具箱 范数为 1 的 d 维向量的集合是等角的如果任意两个之间的内积的绝对值不同的向量等于常数 c。 如果常数c为等角向量,则称其为紧密达到韦尔奇的下界。 输出矩阵 E 的列是等角紧框架E的每一列的范数为1 每对列之间的内积为 1/sqrt(p^deg) E 的列代表等角线在 (p^deg+1)/2 维欧几里得空间中 例子: >> ight_frame_paley(5) 答案 = 0.0000 0.8944 0.2764 -0.7236 -0.7236 0.2764 -0.0000 -0.0000 -0.8507 -0.5257 0.5257 0.8507 -1.0000 -0.4472 -0.4472 -0.447
2024-08-07 09:46:59 2KB matlab
1
该IC多时间可编程模式(MTP)内存来存储芯片上的gamma和VCOM代码,消除外部EEPROM的需求。
2024-08-05 13:41:08 89KB MAX9679B Gamma
1