数据结构 | 北京大学期末试卷查漏补缺

目录

顺序存储

优点

缺点 

适用于: 

链式存储 

优点 

缺点 

适用于:

折半查找为什么要使用顺序存储结构

树的存储结构​编辑

对于一个数据结构,一般包括 

DFS&BFS

什么是递归程序 

C语言不带头结点的单链表逆置 

检测字符串是否对称


​​​​​​​

顺序存储

优点

支持随机访问

不会因为元素之间的逻辑关系而产生额外的存储空间

快速存取元素

缺点 

删除和插入元素的时候要移动大量元素

当线性表变化比较大时,难以确定存储空间的容量

容易产生存储空间碎片 

适用于: 

当线性表容量已知;元素变动不大,需要快速存取元素

链式存储 

优点 

需要删除和插入元素,只需要改变后继指针

缺点 

添加了后继指针,需要更多的储存空间 

适用于:

容量不定,需要频繁删除和添加元素 


折半查找为什么要使用顺序存储结构

折半查找要求使用顺序存储结构,主要是因为这种结构能够提供直接访问元素的能力。在顺序存储结构中,元素按照顺序存储在连续的存储空间中,通常是数组。通过下标可以直接访问元素,这使得折半查找算法能够快速找到中间元素并进行比较。

此外,折半查找还需要表中元素按关键字有序排列。如果元素无序排列,那么无法保证中间元素的大小关系,导致无法准确确定查找范围,从而无法正确找到目标元素。因此,顺序存储结构和有序排列是实现折半查找的必要条件。



树的存储结构

将两个或两个以上的有序表合并成一个新的有序表采用

对于一个数据结构,一般包括 

DFS&BFS

什么是递归程序 


 

C语言不带头结点的单链表逆置 

C语言实现不带头结点的单链表逆置的三种方法_不带头节点的单链表逆置-CSDN博客 

#include <stdio.h>  
#include <stdlib.h>  
  
// 定义链表节点结构体  
struct ListNode {  
    int val;  
    struct ListNode *next;  
};  
  
// 逆置链表函数  
struct ListNode* reverseList(struct ListNode* head) {  
    struct ListNode *prev = NULL, *curr = head, *next = NULL;  
    while (curr != NULL) {  
        next = curr->next;  
        curr->next = prev;  
        prev = curr;  
        curr = next;  
    }  
    return prev;  
}  
  
// 打印链表函数  
void printList(struct ListNode* head) {  
    struct ListNode *curr = head;  
    while (curr != NULL) {  
        printf("%d ", curr->val);  
        curr = curr->next;  
    }  
    printf("\n");  
}  

检测字符串是否对称

#include <iostream>  
#include <string>  
  
using namespace std;  
  
int f(string s) {  
    int n = s.length();  
    for (int i = 0; i < n / 2; i++) {  
        if (s[i] != s[n - i - 1]) {  
            return 0;  
        }  
    }  
    return 1;  
}  
  
int main() {  
    string s1 = "abba";  
    string s2 = "abab";  
    int result1 = f(s1);  
    int result2 = f(s2);  
    cout << result1 << endl;  // 输出1  
    cout << result2 << endl;  // 输出0  
    return 0;  
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/263161.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

fiddler mock数据返回

1.将需要修改的接口copy response 保存在本地txt文档 2.fiddler设置auto response 参考文章&#xff1a; https://www.jianshu.com/p/a06a17ebb0f8 https://blog.csdn.net/m0_59681797/article/details/134338416

docker学习(十一、Redis集群存储数据方式)

文章目录 一、集群数据存储1.单机连接集群问题2.集群方式连接redis存储数据 二、 查看集群信息 docker搭建Redis集群相关知识&#xff1a; docker学习&#xff08;九、分布式存储亿级数据知识&#xff09; docker学习&#xff08;十、搭建redis集群&#xff0c;三主三从&#x…

c++学习笔记-提高篇-STL标准模板库3(stack容器、queue容器以及list容器)

目录 Stack容器 一、Stack容器介绍 二、stack常用接口 三、栈的示例 queue&#xff08;队列&#xff09;容器 一、queue容器介绍 二、queue常用接口 三、queue示例 list容器 一、list容器介绍 二、list常用接口及示例 &#xff08;一&#xff09;list构造函数 &am…

远舢智能入选国家智慧能源产业联盟理事单位 远舢OS擘画绿色能源新蓝图

近日&#xff0c;中关村智慧能源产业联盟2023年会员大会暨数字技术赋能能源转型论坛在京召开。大会审议通过了北京远舢智能科技有限公司&#xff08;以下简称“远舢智能”&#xff09;成为联盟新任理事单位&#xff0c;将与国务院发展研究中心、国家电投、清华大学等国家重点单…

GD32移植STM32工程(因为懒,所以移植)

文章目录 一、前言二、差异性三、软件移植部分1.前期准备1.1 安装GD32固件库1.2 选择所用芯片 2.修改程序2.1 启动时间&#xff08;内部时钟可不改&#xff09;2.2 主频2.2.1 系统时钟配置2.2.2 108MHz宏定义第一处第二处第三处第四处第五处 2.2.3 串口2.2.4 FLASH 四、总结 一…

js执行机制

同步任务 同步任务都在主线程上执行&#xff0c;形成一个执行栈&#xff0c;程序执行的时候&#xff0c;按照顺序依次执行 异步任务 异步任务是通过回调函数实现的&#xff0c;程序执行的时候&#xff0c;程序会调过某个步骤继续向下执行 事件循环 描述了计算机在执行js时…

软件渗透测试有哪些测试流程?权威安全测试报告的重要性

软件渗透测试也是安全测试的一种&#xff0c;是通过模拟恶意黑客的攻击方法&#xff0c;来评估计算机网络系统安全的一种评估方法。作为网络安全防范的一种新技术&#xff0c;对于网络安全组织具有实际应用价值。 一、软件渗透测试的过程   软件渗透测试的过程通常包括四个主…

软考中级应该选哪个?

选择软考中级科目&#xff0c;应该怎么做&#xff1f; 1.1 软考中级科目有哪些可供选择&#xff1f; 1.2 如何选择适合自己的软考中级科目&#xff1f; 系统集成项目管理工程师真的容易吗&#xff1f; 如何在软考中级阶段选择科目&#xff1f;软考中级共有15个科目。软考共…

js中的Array.from()和Array.of()方法的用法详情

&#x1f601; 作者简介&#xff1a;一名大四的学生&#xff0c;致力学习前端开发技术 ⭐️个人主页&#xff1a;夜宵饽饽的主页 ❔ 系列专栏&#xff1a;JavaScript小贴士 &#x1f450;学习格言&#xff1a;成功不是终点&#xff0c;失败也并非末日&#xff0c;最重要的是继续…

【动画图解】一次理清九大排序算法!面试官问到再也不慌!

排序算法 交换排序 冒泡排序快速排序 插入排序 直接插入排序希尔排序 选择排序 简单选择排序堆排序 归并排序基数排序桶排序 一、冒泡排序 冒泡排序是一种简单的交换排序算法&#xff0c;以升序排序为例&#xff0c;其核心思想是&#xff1a; 从第一个元素开始&#xff0c…

帕累托森林CEO李朝政博士受邀「OSS-Compass」开源年会畅谈:开源框架下的奇异竞争规则

导语 “怎么在别人知道你的代码和战略时&#xff0c;你仍然拥有壁垒&#xff1f;”这是开源框架下&#xff0c;商业必须思考的问题。 软件驱动世界运转。但当基础层代码失去了有深度活力的“动态延伸”潜力&#xff0c;便会遭致市场“零定价”的宿命。动态延伸的效率&#xf…

Docker概述及介绍

Docker是近年来新兴的虚拟化工具&#xff0c;它可以和虚拟机一样实现资源和系统环境的隔离。 库&#xff0c;然后再安装应用&#xff1b; Container(Docker容器)&#xff0c;在宿主机器、宿主机器操作系统上创建Docker引擎&#xff0c;在引擎的基础上再安装应用。 Docker三…

华为设备VRP基础

交换机可以隔离冲突域&#xff0c;路由器可以隔离广播域&#xff0c;这两种设备在企业网络中应用越来越广泛。随着越来越多的终端接入到网络中&#xff0c;网络设备的负担也越来越重&#xff0c;这时网络设备可以通过华为专有的VRP系统来提升运行效率。通用路由平台VRP&#xf…

华为Harmony——ArkTs语言

文章目录 一、简单示例二、声明式UI描述创建组件无参有参数 配置属性配置事件配置子组件 三、自定义组件基本用法基本结构成员函数/变量 一、简单示例 我们以一个具体的示例来说明ArkTS的基本组成。如下图所示&#xff0c;当开发者点击按钮时&#xff0c;文本内容从“Hello Wo…

Python 爬虫之下载视频(二)

爬取某Y的视频链接和标题 文章目录 爬取某Y的视频链接和标题前言一、基本思路二、程序解析阶段三、程序处理阶段总结 前言 这篇内容就简单给大家写个如何从网页上爬取某B主 主页 页面上所有的视频链接和视频标题。 这篇是基础好好看&#xff0c;下篇会根据这篇的结果做一个批…

如何在小程序中添加字符

随着移动互联网的普及&#xff0c;微信小程序已经成为众多商家的首选。通过微信小程序&#xff0c;商家可以展示产品、服务和品牌形象。那么如何在微信小程序中添加视频内容呢&#xff1f;本文将详细介绍操作步骤。 首先&#xff0c;商家需要登录乔拓云平台&#xff0c;进入门店…

什么是密钥扩展?如何确保密码安全?

为了访问自己的数字账户&#xff0c;我们通常需要用到密码或口令。不过&#xff0c;正如现实生活中开锁的钥匙可能并不总是牢靠一样&#xff0c;并非所有的密码都是安全的。为了加强在线防御&#xff0c;安全专家开发了一系列技术和方法&#xff0c;来提高密码的安全性。这些方…

SecGPT:全球首个网络安全开源大模型

2023年是人工智能的奇迹年&#xff0c;OpenAI的ChatGPT横空出世&#xff0c;在自然语言的人机对话领域实现了突破性的智能表现。人工智能技术的革命性应用已在各行业引发了热潮&#xff0c;医疗、金融、法律等领域都涌现出了垂类开源大模型&#xff0c;为行业应用带来了无限可能…

【科学计算语言】实验四 科学计算与可视化

【目的和要求】 &#xff08;1&#xff09;理解科学计算实质并掌握Python语言的科学计算应用 &#xff08;2&#xff09;掌握常用科学计算库 &#xff08;3&#xff09;熟练运用numpy及scipy、matplotlib等计算库资源 【实验准备】 Python核心科学计算库的导入、配置并熟悉相关…