考研

标题: 2023年西安交通大学915计算机软件基础考研考试大纲及参考书 [打印本页]

作者: dayday    时间: 2022-11-17 18:56
标题: 2023年西安交通大学915计算机软件基础考研考试大纲及参考书

2023年计算机软件基础考试大纲

考试科目:数据结构与算法、程序设计基础

考试形式和试卷结构

参考书

1.《数据结构(第二版)》清华大学出版社,1992年6月严蔚敏第二版

2.《程序设计与C语言》西安交通大学出版社,2005年8月梁力第二版

一、试卷满分及考试时间

试卷满分为150分,考试时间为180分钟。

二、试卷内容结构

数据结构与算法约80%

程序设计基础约20%

三、试卷题型结构

单项选择题10小题,每小题2分,共20分

填空题10小题,每小题2分,共20分

解答题7-8小题,共80分

程序设计题2-3小题,共30分

数据结构与算法

一、数据结构基本概念

考试内容

数据、数据元素、数据项、数据对象、数据结构的定义;

数据的逻辑结构、数据的物理结构、数据的运算的定义;

数据类型以及抽象数据类型的定义。

考试要求

掌握数据、数据元素、数据项之间的关系;

掌握数据结构的定义;

掌握数据结构的三要素;

掌握数据类型、抽象数据类型和数据结构之间的关系。

二、算法和算法分析

考试内容

算法的定义、算法的特性、算法的时间复杂度和算法的空间复杂度的定义及计算。

考试要求

了解算法的定义以及特性;

了解衡量算法在资源上的两个方面;

掌握算法的渐进性分析方法,会用该方法对算法进行评估;

掌握Ο标记法,理解大Ο标记法的意义;

掌握Ω标记法,理解大Ω标记法的意义;

掌握Θ标记法,理解大Θ标记法的意义;

了解时空权衡原则。

三、线性表

考试内容

线性表的定义;

顺序表的定义及其特点;

链式表的定义及其特点;

线性表的应用。

考试要求

掌握线性表的逻辑结构,以及基本操作;

掌握用顺序存储结构对线性表基本操作的实现;

掌握链式存储结构对线性表基本操作的实现;

掌握链式存储结构的实现技术,比如单向链表、双向链表、单循环链表、双向循环链表以及带头节点的链表;

具有在实际中选取不同存储结构的判断能力。

四、栈和队列

考试内容

栈和队列的定义;

顺序栈和链式栈的定义及其特点;

顺序队列和链式队列的定义及其特点;

栈和队列的应用。

考试要求

掌握栈、队列的逻辑结构,以及基本操作;

掌握顺序存储结构对栈和队列基本操作的实现;

掌握链式存储结构对栈和队列基本操作的实现;

掌握顺序存储结构中实现循环队列的具体要求;

理解递归调用和栈之间的关系;

掌握栈和队列的经典应用。

五、二叉树、树和森林

考试内容

二叉树、树和森林的定义;

二叉树的实现(包括顺序存储结构和链式存储结构)、二叉树的遍历;

二叉树结构下的应用及扩展,例如二叉检索树、2-3-4树、B树、B+树、Huffman编码以及堆;

平衡二叉树的定义、平衡因子的定义以及平衡二叉树的旋转操作;

树和森林的存储结构、树和森林的遍历以及森林与二叉树的转换;

森林结构的应用,例如并查集。

考试要求

掌握二叉树、树和森林的定义以及它们之间的异同点;

掌握二叉树的四种遍历,并具有能够依赖遍历完成对二叉树进行操作的能力;

理解二叉树采用顺序存储结构和链式存储结构的差异性;

掌握利用二叉树及其扩展下的检索技术;

掌握Huffman编码、堆的实现及应用;

理解平衡二叉树的意义;

掌握平衡二叉树的旋转操作;

掌握树、森林能够采用的各种存储方式的差异性;

掌握树和森林与二叉树的转换;

掌握树、森林在遍历方面和二叉树的不同以及相关性;

理解并查集的意义,以及掌握并查集的基本操作的实现。

六、图

考试内容

图的定义;

图的实现(包括邻接矩阵和邻接表)和基本操作;

图的两种遍历;

图的基本应用,包括最小支撑树、最短路径、拓扑排序和关键路径。

考试要求

掌握图的定义,包括完全图、连通图、简单路径、有向图、无向图、无环图等,明确理解图和二叉树、树和森林这种结构之间的异同点;

掌握图采用邻接矩阵和邻接表进行存储的差异性;

掌握广度优先遍历和深度优先遍历;

掌握最小支撑树(Prim算法、Kruskal算法)、最短路径(Dijkstra算法、BellmanFord算法、Floyd算法)、拓扑排序以及关键路径的实现过程。

七、查找

考试内容

查找的定义;

查找的如下算法:顺序查找法、折半查找法、散列(Hash)技术。

考试要求

理解查找的定义;

掌握对查找算法进行衡量的一些指标:平均查找长度、成功查找的查找长度、不成功查找的查找长度;

掌握顺序查找法和折半查找法,并理解二者之间的异同点;

掌握散列技术,包括散列函数、散列表、散列冲突的发生及其解决方法、以及负载因子;

理解不同查找技术的优缺点。

八、排序

考试内容

排序的定义,包括内排序和外排序;

排序的稳定性定义;

直接插入排序、冒泡排序、简单选择排序、Shell排序、快速排序、堆排序、归并排序、基数排序、K路归并排序的排序过程。

考试要求

理解内排序和外排序的区别;

掌握排序的稳定性;

对直接插入排序、冒泡排序、简单选择排序、Shell排序、快速排序、堆排序、归并排序、基数排序这些算法,掌握其在时间复杂度、空间复杂度以及是否稳定等方面的特点;

了解K路归并的外排序算法;

具有在不同的应用需求下,能够根据各种排序算法特点选择合适排序算法的能力。

九、矩阵和串

考试内容

矩阵和串的定义;

特殊矩阵的压缩存储、稀疏矩阵的三元组表示法;

串的模式匹配。

考试要求

掌握特殊矩阵的压缩存储方法;

掌握稀疏矩阵的三元组表示法以及相应的操作;

掌握多维数组和一维数组的映射;

掌握模式匹配的两个算法:Brute-Force和KMP。

程序设计基础

一、基本输入输出

考试内容

控制台形式的输入语法;

控制台形式的输出语法;

考试要求

掌握对不同类型数据的控制台输入方法;

掌握对不同类型数据的控制台输出方法,包括一些输出格式。

二、数据类型及运算

考试内容

相应编程语言内置的数据类型的使用;

相应编程语言内置的运算符的使用;

相应编程语言对自定义数据类型的语法。

考试要求

掌握语言内置的数据类型的正确定义、声明和使用;

掌握语言内置的运算符的正确使用;

具有自定义数据类型的能力。

三、语句

考试内容

顺序语句、选择语句和循环语句。

考试要求

掌握相应语言对顺序语句、选择语句和循环语句的语法以及运用。

四、函数

考试内容

函数的语法定义;

函数的嵌套调用,特别包括递归调用。

考试要求

掌握相应语言对函数定义的语法;

掌握递归思想,具有能够合理使用函数递归调用完成算法设计与实现的能力。

想了解更多可关注新祥旭陕西考研公众号。


最后别忘了到沪学网下载免费课程!




欢迎光临 考研 (https://www.kaoyan.co/) Powered by Discuz! X3.5