数据结构-分析期末选择题考点(串、数组)

news2024/12/23 8:49:58

竹月光中诗世界

松风影里酒生涯

目录

 串的常见考法(一)BF算法

 串的常见考法(二)KMP求 next数组

串的常见考法(三)串的概念及性质

串的常见考法(四)给出主串求子串数量

数组的常见考法(一)计算二维数组中的某个空间地址

 数组的常见考法(二)二维数组下标的计算

数组的常见考法(三)给出表达式求个数 

契子


承接上回,我们来复习串这一章的内容 ~

说到,其实也不难,不过考点分布算是有点多。这里我们依旧是以题型进行分析:

<1> BF算法:一般考主串在哪个位置与子串匹配 (大概率)

<2> KMP算法:给出一个串求其 next 数组 (大概率)

<3> 串的概念以及性质(比如说特殊线性表,存储的数据元素是字符)

<4>给出一个主串子串数量

串的大概考点便是以上这些,我们再来聊一聊数组
考数组的话,肯定是不会给你一维数组的,要考也是考二维,常以计算一个二维数组中的某个空间地址出题

<1>计算二维数组中的某个空间地址

<2>二维数组下标的计算(可能会结合一维数组考)

<3>给出几维数组表达式求几维数组元素个数


 

 串的常见考法(一)BF算法

StrIndex (‘DATASTRUCTURE',1,‘STR')= ()。
A. 3
B. 7
C. 5
D. 9

首先我先来说明一下 StrIndex 这个函数的意思:

主串 DATASTRUCTURE 中的第 1 个位置找到子串 STR 的位置并返回,若是找不到则返回 -1

所以这是一个字符串匹配的题目,我们只需简单的数一下从主串的第一个位置到子串的位置的距离便可以啦 ~


所以答案选择 C

S1='good',S2='morning',执行函数SubStr(S2,4,LenStr(S1))后的结果为()。
A. 'good'
B. 'go'
C. 'morn'
D. 'ning'

我先来说一下 SuStrLenStr 的功能:

(1)substr()是 C++ 函数,主要功能是复制子字符串,要求从指定位置开始,并具有指定的长度。如果没有指定长度或超出了源字符串的长度,则子字符串将延续到源字符串的结尾

(2)strlen 是C语言的函数用来求字符串的长度

所以我们的题目应该这么理解,在 S2(morning )中的第 4 个位置复制 S1(good)长度个并存储在临时空间,S2的第 4 个位置便是 n,所以结果便是 n 开始的后面 4 个字符


所以答案选择 D

 串的常见考法(二)KMP求 next数组

感觉这个有点不好讲,因为我不知道大家的基础是怎么样的,需不需要提一下 KMP 算法,算了还是提一下吧

其实做着种类型题其实不需要懂多少 KMP 的东西

只要知道最长公共前后缀怎么算就可以 KO 这道题

我现在先讲讲:

💞公共前后缀就是字符串前缀与后缀的集合中的相等部分

对于字符串 abab 来说:
前缀 [a,ab,aba],后缀 [b,ab,bab],那么公共前后缀也就是 [ab],长度为2
公共前后缀是可以重合的:
[ababa]的前缀[aba]和后缀[aba]公共前后缀的长度就是3

我们知道这个知识点便可以做题了


我们先来个简单点的,看下面的类型题

串“abcac”的next数组为(  )。

我们数组的第一和第二位置直接无脑 0、1(固定的)

然后到我们的 c 位置(第三位置),就看前面那些写好 next 数组的串有没有公共前后缀

如果没有便写入 1,如果有就 1 加上最长公共前后缀的长度

我们这里看的是 ab 所以没有公共前后缀,所以写上 1 即可

这里稍微快进一下

这个时候我们来到 c 位置,我们看的便是 abca 这个串,它有公共前后缀 a 且是最大的,所以我们就要 1 加上它的长度,便是 2


是不是很简单,我们再看一道题:

串“ababaaababaa”的next数组为()
A. 012345678999   
B.012121111212   
C.011234223456    
D.0123012322345

我们还是按照之前的方法,开局无脑 01,虽然说答案都是 01,但是要一步一步来

然后开始在看看有没有公共前后缀

<1>没有直接写 1

<2>有便用 1 加上最长公共前后缀,在我们 b(第4个位置)这个地方,前面的串是 ab

那么最长公共前后缀为 1,加上便是 2

这里就不说明了,直接看图吧

这里就是我之前提到过的:公共前后缀是可以重叠的(所以这里公共前后缀是3)

按步骤反复,便可以得出结果了:

所以答案选择 C

方法想必已经教会你们了,所以我就来讲讲别的题型啦 ~ 

 

串的常见考法(三)串的概念性质

像这种概念题都考得很简单,我这里就直接给出答案了,放在这里只是为了让你们更好的了解题目

(1)串是一种特殊的线性表,其特殊性体现在(  )。

A.可以顺序存储               B.数据元素是一个字符      

C.可以链式存储               D.数据元素可以是多个字符若

答案选 B

(2)串下面关于串的的叙述中,(  )是不正确的?

A.串是字符的有限序列           B.空串是由空格构成的串

C.模式匹配是串的一种重要运算    D.串既可以采用顺序存储,也可以采用链式存储

答案选 B

串的长度是指( )。
A.串中所含不同字母的个数
B.串中所含字符的个数
C.串中所含不同字符的个数
D.串中所含非空格字符的个数

答案选 B

设有两个串p和q,其中q是p的子串,求q在p中首次出现的位置的算法称为()。
A.求子串
B.联接
C.匹配
D.求串长

答案选 C

如下陈述中正确的是()
A.串中元素只能是字母
B.串的长度必须大于零
C.串是一种特殊的线性表
D.空串就是空白串

答案选 C

串的常见考法(四)给出主串子串数量

若串S=“software”,其子串的个数是()。
A.8
B.37
C.36
D.9

大概就是像这样的题型,我们得到一个主串要求出子串

这其实就是初中题好吧,不过有一点要注意的是:子串还包含空串哦

所以这就是相似的选项相差 1 的原因,就是为了坑你!

然后就是找规律了,不过不想找的话就慢慢枚举吧

首先,software 没有重复字符,长度为8
1个字符的子串有8个;
2个字符的子串有8-1个;
3个字符的子串有8-2个;
... ...
7个字符的子串有8-6个;
8个字符的子串有8-7个。
所以子串总数是1+2+3...+8=36个

但是字串还包含空字串,所以我们还需要加上 1

所以这道题的答案选择 B

这里总结稍微一下规律:

字串: n(n+1)/2 + 1
非空子串:n(n+1)/2
非空真子串(不包括空串和跟自己一样的子串):n(n+1)/2 - 1

 

 接下来为我们就来总结一下数组吧 ~ 学了那么久的程序,数组还解决不了吗?

数组的常见考法(一)计算二维数组中的某个空间地址

首先讲一下概念(公式)吧 ~

二维数组默认按行存储
A[i][j]的地址 = 基地址 + i * 列数 * 每个元素占的字节数 + j * 每个元素占的字节数

二维数组是 m 行 n 列,行下标和列下标都从0开始
loc[i,j] = 首地址+(i*n +j)*每个数据元素的大小

二维数组是 m 行 n 列,行下标和列下标都从1开始
loc[i,j] = 首地址+((i-1)*n +(j-1))*每个数据元素的大小
二维数组默认按列存储
A[i][j]的地址 = 基地址 + i * 行数 * 每个元素占的字节数 + j * 每个元素占的字节数

二维数组是 m 行 n 列,行下标和列下标都从0开始
loc[i,j] = 首地址 + (j*m + i) * 每个数据元素的大小

二维数组是 m 行 n 列,行下标和列下标都从1开始
loc[i,j] = 首地址 + ((j-1)*m + (i-1)) * 每个数据元素的大小

 

假设以行序为主序存储二维数组A=array[1..100,1..100],设每个数据元素占2个存储单元,基地址为10
则LOC[5,5]=(  )。
A. 808
B. 1010
C. 818
D. 1020

面对这个题你有两种选择:要么记公式要么画图模拟

画图的话这里就不说了,不过是画图推出公式而已 ~

对了,有一点需要注意,如果题目没有特别说明,我们的数组都是默认0 开始的,这里比较特殊是从 1 开始的,我们就简单的套一下公式吧

loc[5,5] = 10 + ((5-1)*100 + (5-1)) * 2

算出结果为 818 

所以答案选择 C

设有一个10阶的对称矩阵A,采用压缩存储方式,以行序为主存储,a11为第一元素,其存储地址为1
每个元素占一个地址空间,则a85的地址为()。
A、13
B、33
C、18
D、40
由于是对称矩阵,因此压缩存储可以认为只要存储下三角矩阵。
(1,1)                                          1
(2,1) (2,2)                                    2
(3,1) (3,2) (3,3)                              3
(4,1) (4,2) (4,3) (4,4)                        4
(5,1) (5,2) (5,3) (5,4) (5,5)                  5 
(6,1) (6,2) (6,3) (6,4) (6,5) (6,6)            6
(7,1) (7,2) (7,3) (7,4) (7,5) (7,6) (7,7)      7 
(8,1) (8,2) (8,3) (8,4) (8,5)                  5


1+2+3+4+5+6+7+5=33

首先我们得矩阵是从(1,1)开始的,因为矩阵是对称的,所以我们只需要画出一半的图形便可以直观的做出来

这里可以推一下公式:

k 代表要求的空间地址,i 表示行,j 表示列

k=(i*(i-1)/2)+j

所以答案选择 B

 数组的常见考法(二)二维数组下标的计算

设二维数组A[1.. m,1.. n](即m行n列)按行存储在数组B[1.. m*n]中
则二维数组元素A[i,j]在一维数组B中的下标为()
A. (i-1)*n+j 
B. (i-1)*n+j-1
C. i*(j-1)
D. j*m+i-1

其实像这种题如果不会的话可以画图来理解一下的

我们的二维数组中的 22 放在一维数组中是什么地位?

放在我们一维数组来看也就是说:地位 = 上面层数 + 当前序列

设当前层数为 i,当前序列为 j

因为我们的 22 在二维数组中是在第二行的第二个位置,但是由于我们不是从 0 开始而是从 1 开始所以我们需要 (i-1),因为有 n 列所以我们需要乘以 n,即:(i-1)*n

我们的 22 在二维数组的第 2 位,所以需要 + j

模拟完了,答案自然也就出来了

所以答案选择 A

数组的常见考法(三)给出表达式求个数

数组A[0..4,-1..-3,5..7]中含有元素的个数()
A. 55
B. 45
C. 36
D. 16

可以看到题目给我们的是一个三位数组,但是不要慌,求个数而已,想一想我们一维二维怎么求个数的,三维就怎么求

简单来说这道题就是小学题,不过将其包装了一下

一维数组我们就想象成一条线,我们求一条线的长度不是直接去量?(看)

二维数组我们就想象成一个长方形,我们长乘宽不就成了

三维数组我们就想象成长方体,长乘宽乘高,这就是这道题的做法

我们需要找到(长、宽、高)才能算出其个数,而我们所谓的长、宽、高便是每个维的个数

每维个数 = 上限 - 下限 + 1

4-0+1=5

-1-(-3)+1=3

7-5+1=3

最后:5*3*3=45 便可以求出三维数组的个数了

所以答案选择 B

 

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Postman 怎么测接口?实用教程

在当前&#xff0c;API&#xff08;应用程序接口&#xff09;的使用变得越来越普遍。其中&#xff0c;HTTP/HTTPS API 是最常见的一种。无论是开发前端还是后端&#xff0c;测试 API 都是一个关键环节。Postman 是一种流行且强大的 API 测试工具&#xff0c;能够帮助开发人员轻…

【php】【mysql】【layui】 原生初级简易留言簿系统成品代码动态网站开发网页WEB浏览器端B/S结构

更多项目点击&#x1f446;&#x1f446;&#x1f446;完整项目成品专栏 【php】【mysql】【layui】 原生初级简易留言簿系统成品代码动态网站开发网页WEB浏览器端B/S结构 获取源码方式项目说明&#xff1a;文件包含&#xff1a;项目运行环境项目运行截图 获取源码方式 加Q群…

ASUS/华硕幻13 2022 GV301R系列 原厂Windows11系统

安装后恢复到您开箱的体验界面&#xff0c;带原机所有驱动和软件&#xff0c;包括myasus mcafee office 奥创等。 最适合您电脑的系统&#xff0c;经厂家手调试最佳状态&#xff0c;性能与功耗直接拉满&#xff0c;体验最原汁原味的系统。 原厂系统下载网址&#xff1a;http:…

jeecg启动微服务并注册到本地nacos

1、maven勾选环境和微服务模式&#xff0c;并刷新 2、pom文件修改nacos注册地址 3、本地启nacos gateway 和自己想要的cloud下面的模块pos sys 4、打断点测试接口&#xff0c;访问gateway端口和想要测试的地址

抖音团购达人实战营,抖音团购达人从0-1教程(11节课)

课程目录&#xff1a; 1-团购达人先导课1.mp4 2-账号措建.mp4 2-账号搭建_1.mp4 3-开通团购达人_1.mp4 4-账号养号涨粉套路_1.mp4 5-团购选品正确姿势_1.mp4 6-短视频之混剪课_1.mp4 7-短视频之图文课_1.mp4 8-短视频之口播课_1.mp4 9-短视频运营策略_1.mp4 10-团购…

搭建企业内网pypi镜像库,让python在内网也能像互联网一样安装pip库

目录 知识点实验1.服务器安装python2.新建一个目录/mirror/pip&#xff0c;用于存储pypi文件&#xff0c;作为仓库目录3.下载python中的所需包放至仓库文件夹/mirror/pip3.1. 新建requirement.py脚本&#xff08;将清华pypi镜像库文件列表粘贴到requirement.txt文件中&#xff…

宝塔计划任务调用node程序时,log4js日志保存本地位置会发生变化

接我上一篇文章的情况 超简单的nodejs使用log4js保存日志到本地&#xff08;可直接复制使用&#xff09;-CSDN博客 原本应当保存在node项目目录下的日志文件&#xff0c;如果使用宝塔的计划任务来定时执行的话&#xff0c;日志保存路径会发生变化到如下图的位置&#xff1a; 如…

MyBatis-关联查询的对象是集合的处理

用户和角色之间是多对多的关系&#xff0c;也就是说&#xff0c;一个用户可以有多个角色与之绑定&#xff0c;所以在User对象中&#xff0c;角色的属性就必须是一个集合Set或者List&#xff0c;这里我们就用List集合在做例子&#xff1a; 1.怎么在Mybatis中实现关联的List集合对…

脚本实现登陆滑块

脚本实现登陆滑块 仅供学习参考&#xff0c;简单操作 你知道吗&#xff0c;滑动验证码居然是为了验证人类比机器人蠢而设计的。 你以为自己快速、准确地滑动拼图、对齐图案&#xff0c;才被允许通过&#xff0c;系统还说你超越了99%的用户&#xff0c;夸你“比闪电还快”&am…

【逆运动学】六轴机器人运动学逆解上位机控制

六轴机器人逆运动学上位机控制 最终效果 通过开发的上位机软件&#xff0c;实现对机械臂末端的精准操控。该软件接收输入的坐标与角度参数&#xff0c;经过算法处理计算出机械臂各关节轴的目标角度。随后&#xff0c;这些角度值被转换为对应的脉冲宽度调制&#xff08;PWM&am…

QT在visual studio环境打开控制台窗口

明确需求 在VS环境中开发QT应用&#xff0c;有时遇到BUG想看日志&#xff0c;但是默认VS环境没有显示控制台窗口可看日志。 解决方法 对工程名单击右键。 点击属性&#xff0c;在打开界面按照如下图操作。 设置完成后弹出的控制台窗口如下图。

vue-router的学习

vue-router 基于Vue做单页面应用时&#xff0c;vue-router可以帮我们将url地址和组件绑定&#xff0c;在我们切换路由组件时&#xff0c;url改变&#xff0c;页面无需从服务端重新加载&#xff0c;即不用刷新&#xff0c;打个比方&#xff0c;我们用美团外卖点外卖时&#xff…

Profibus协议转profinet协议网关模块连接电机保护器与PLC通讯

一、背景 工业通讯中常见的协议有&#xff1a;Modbus协议&#xff0c;ModbusTCP协议&#xff0c;Profinet协议&#xff0c;Profibus协议&#xff0c;Profibus DP协议&#xff0c;EtherCAT协议&#xff0c;EtherNET协议等在现代工业控制系统中具有重要的角色。而Profibus协议转…

【强化学习】第02期:动态规划方法

笔者近期上了国科大周晓飞老师《强化学习及其应用》课程&#xff0c;计划整理一个强化学习系列笔记。笔记中所引用的内容部分出自周老师的课程PPT。笔记中如有不到之处&#xff0c;敬请批评指正。 文章目录 2.1 动态规划&#xff1a;策略收敛法/策略迭代法2.2 动态规划&#xf…

C# SocketUDP服务器,组播

SocketUDP 自己即是服务器又是客户端 &#xff0c;在发消息只需要改成对方ip和端口号即可 前提对方必须开启服务器 socket.Bind(new IPEndPoint(IPAddress.Parse("192.168.107.72"), 8080)); 控件&#xff1a;Button,TextBox,RichTextBox 打开自己服务器 public…

C++编译时引入json/nlohmann文件报错

报错信息: In file included from /home/chenlang/catkin_ws/src/leanrning_communication/src/mysql/../utils/data.h:14:0,from /home/chenlang/catkin_ws/src/leanrning_communication/src/mysql/MyRobotDb.h:32,from /home/chenlang/catkin_ws/src/leanrning_communicatio…

K8S 角色/组件及部署方式的简单概述

1.宏观架构图 2.角色详情 2.1 Master(Controller Plane) 早期是叫 Master 节点&#xff0c;后期改名为 Controller Plane&#xff0c;负责整个集群的控制和管理 Master 不会干活的(当然你让它干也是会干的&#xff0c;涉及到污点容忍)&#xff0c;而是起到访问入口&#xff…

Java编程基本功大揭秘 | 详解深入分析Java线程池源码和底层原理,掌握实战技巧【1】

详解深入分析Java线程池源码和底层原理 文章大纲引言Java线程池概念及重要性 ThreadPoolExecutor类的概述ThreadPoolExecutor类的基本功能和作用**基本功能****核心作用** ThreadPoolExecutor主要构造函数及其参数继承关系链功能介绍ThreadPoolExecutor 构造器构造器参数构造器…

单源最短路径问题(Dijstra)

#include<iostream> using namespace std; #define MAX 500 #define INT 999 typedef struct {char vex[MAX];int Edge[MAX][MAX];int vexnum,arcnum; }MGraph; void InitMG(MGraph &MG) {cout<<"输入顶点数和边数&#xff1a;";cin>>MG.vexnu…

代码随想录算法训练营第三十七天|01背包问题、分割等和子集

01背包问题 题目链接&#xff1a;46. 携带研究材料 文档讲解&#xff1a;代码随想录 状态&#xff1a;忘了 二维dp 问题1&#xff1a;为啥会想到i代表第几个物品&#xff0c;j代表容量变化&#xff1f; 动态规划中&#xff0c;每次决策都依赖于前一个状态的结果&#xff0c;在…