川农大算法分析期末复习_第1页
川农大算法分析期末复习_第2页
川农大算法分析期末复习_第3页
川农大算法分析期末复习_第4页
川农大算法分析期末复习_第5页
已阅读5页,还剩47页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

算法分析与设计复习题判断题1选择题:15判断题算法就是一组有穷的规则。答案:正确概率算法中蒙特卡罗算法得到的解必是正确的。答案:错误程序和算法一样,都是某种程序设计语言的具体实现。答案:错误合并排序算法是渐近最优算法。答案:正确递归定义必须是有确切含义是指必须一步比一步简单,最后是有终结的,决不能无限循环下去。答案:正确二分搜索方法在最坏的情况下用0(10。n)时间完成搜索任务。答案:正确能否利用分治法完全取决于问题是否具有如下特征:利用该问题分解出的子问题的解可以合并为该问题的解。答案:正确分治法的基本思想是将一个规模较大的问题分解成若干个规模较小的子问题,这些子问题之间并不一定相互独立。答案:错误递归算法的效率往往很低,费时和费存空间。答案:正确当一个问题具有最优子结构性质时只能用动态规划方法求解。答案:错误如果一类活动过程一个阶段的决策确定以后,常影响到下一个阶段的决策,则称它为多阶段决策问题。答案:正确反复应用分治手段,不能使子问题与原问题类型一致而其规模却不断缩小。答案:错误裴波那契数列的定义:£(口)=£(口-1)+£(口-2”(0)=廿(1)=2,其数据的定义形式不是按递归定义。答案:错误0-1背包问题与背包问题这两类问题都可以用贪心算法求解。答案:错误证明贪心选择后的问题简化为规模更小的类似子问题的关键在于利用该问题的最优子结构性质。答案:错误子问题之间不包含公共的子问题,这个条件涉及到分治法的效率。答案:正确概率算法允许在执行过程中随机地选择下一个计算步骤。答案:正确二分搜索法的二分查找只适用于顺序存储结构。答案:正确要想在电脑上扩大所处理问题的规模,有效的途径是降低算法的计算复杂度。答案:正确用回溯法解题一个显著特征是在搜索过程中动态产生问题的解空间。答案:错误从分治法的一般设计模式可以看出,用它设计出的程序一般是一个递归过程。因此,分治法的计算效率通常可以用递归方程来进行分析。答案:正确多阶段决策问题中,每一个阶段可能有若干个决策可供选择答案:正确拉斯维加斯算法不会得到不正确的解,但有时找不到解。答案:正确在通往边界条件的递归调用过程中,系统用堆栈保存的每次调用的中间结果是局部变量和返回地址值。答案:正确要想在电脑上扩大所处理问题的规模,有效的途径是提高算法的计算复杂度。答案:错误程序必须满足算法具有数据输出的性质。答案:正确反复应用分治手段,可以使子问题与原问题类型一致而其规模却不断缩小答案:正确一个算法产生一个或多个输出,它们是同输入有某种特定关系的量答案:正确最优子结构性质特征反映了递归思想的应用答案:正确递归边界本身并不使用递归的定义答案:正确用分治法求解一个问题,所需的时间是由子问题的个数、大小以及把这个问题分解为子问题所需的工作总量来确定的。答案:正确应用回溯法解问题时,首先应明确定义问题的解空间。问题的解空间应至少包含问题的一个(最优)解。答案:正确好的约束函数能显著地减少所生成的结点数,但这样的约束函数往往计算量较大。因此,在选择约束函数时通常存在生成结点数与约束函数计算量之间的折衷。答案:正确一个递归定义必须是有确切含义的,必须一步比一步简单,最后是有终结的,不能无限循环下去。答案:正确最优子结构性质是应用分治法的前提。答案:正确操作系统,它是一个在无限循环中执行的程序,因而不是一个算法。答案:正确有些数据结构如二叉树等,由于其本身的递归特性、特别适合用递归的形式来描述。答案:正确概率算法的一个基本特征是,对所求问题的同一个实例用同一个算法求解两次一定能得到完全相同的效果。答案:错误问题可以分解为若干个规模较小的相同问题,即称该问题具有最优子结构性质。答案:错误递推是从边界条件出发,通过递推式达到边界条件。答案:正确所有的递归函数都能找到对应的非递归定义。答案:正确定义递归函数时可以没有初始值。答案:错误动态规划算法的基本要素是最优子结构。答案:正确最优子结构性质是指原问题的最优解包含其子问题的最优解。答案:正确动态规划算法求解问题时,分解出来的子问题相互独立。答案:错误满足贪心选择性质必满足最优子结构性质。答案:错误回溯法中限界函数的目的是剪去得不到最优解的子树。答案:正确分支限界法类似于回溯法,也是一种在问题的解空间树丁上搜索问题解的算法,两者的搜索方式是相同的。答案:错误任何递归算法都有递归出口。答案:正确递归算法的执行效率比功能相同的非递归算法的执行效率高。答案:错误递归算法不能转换成对应的非递归算法。答案:错误数据元素是数据的最小单位答案:错误数据对象就是一组数据元素的集合答案:错误任何数据结构都具备三个基本运算:插入、删除和查找。答案:错误数据对象是由有限个类型相同的数据元素构成的。答案:正确数据的逻辑结构与各数据元素在计算机中如何存储有关。答案:错误如果数据元素值发生改变,则数据的逻辑结构也随之改变。答案:错误逻辑结构相同的数据,可以采用多种不同的存储方法。答案:正确逻辑结构不相同的数据,必须采用不同的存储方法来存储。答案:错误数据的逻辑结构是指数据元素的各数据项之间的逻辑关系。答案:错误顺序存储方式只能用于存储线性结构。答案:错误算法可以用不同的语言来描述,如果用C语言或Pascal语言等高级语言来描述,则算法就等同于程序。答案:错误数据的逻辑结构是指各数据元素之间的逻辑关系。答案:正确数据结构、数据元素、数据项在计算机中的映像(或表示)分别称为存储结构、节点和数据域。答案:正确数据的物理结构是指数据在计算机的实际存储形式。答案:正确分配给单链表的存与地址必须是连续的。答案:错误从长度为n的顺序表中删除任何一个元素,时间复杂度都是0(口)。答案:错误向顺序表中插入一个元素,平均要移动大约一半的元素。答案:正确凡是为空的单链表都是不含任何节点的。答案:错误如果单链表带有头节点,则插入操作永远不会改变头节点指针的值。答案:正确在循环单链表中,任何一个节点的指针域都不可能为空。答案:正确顺序存储方式的特点是存储密度大且插入、删除运算效率高。答案:错误线性表的顺序存储结构优于链式存储结构。答案:错误顺序存储结构属于静态结构而链式存储结构属于动态结构。答案:正确由于顺序存储结构要求连续的存储区域,所以在存储管理上不够灵活。答案:正确对于单链表来说,只有从头节点开始才能扫描表中全部节点。答案:正确对于循环单链表来说,从表中任一节点出发都能扫描表中全部节点。答案:正确双链表的特点是很容易找任一节点的前趋和后继。答案:正确线性表有两种存储结构:一是顺序表,二是链表。答案:正确如果有多个线性表同时共存,并且在处理过程中各表的长度会动态地发生变化,线性表的总数也会自动改变。在此情况下,应选用链式存储结构。答案:正确若线性表的总数基本稳定且很少进行插入和删除操作,但要求以最快的速度存取线性表中的元素,那么应该选用顺序存储结构。答案:正确对于单链表和双链表,均能从当前节点出发访问到任一节点。答案:错误循环单链表和循环双链表从尾指针出发可以访问到链表中的任意节点。答案:正确若频繁地对一个线性表进行插入和删除操作,该线性表宜采用链式存储结构。答案:正确栈底元素是不能删除的元素。答案:错误顺序栈中元素值的大小是有序的。答案:错误栈顶元素和栈底元素有可能是同一个元素。答案:正确若用$[1…团]表示顺序栈的存储空间,则对栈的进栈、出栈操作最多只能进行团次。答案:错误栈是一种对进栈、出栈操作总次数作了限制的线性表。答案:错误空栈没有栈顶指针答案:错误环形队列中有多少元素,可以根据队首指针和队尾指针的值来计算。答案:正确无论是顺序队列,还是链式队列,插入、删除运算的时间复杂度都是0(1)。答案:正确栈和队列都是插入和删除操作受限的线性表。答案:正确栈和队列的存储方式既可以是顺序方式,也可以是链式方式答案:正确环形队列也存在空间溢出的问题答案:正确消除递归不一定需要使用栈。答案:正确二分搜索算法是利用贪心法实现的算法。答案:错误动态规划算法通常是以自底向上的方式求解最优解。答案:正确贪心法不能解决0/1背包问题。答案:正确深度优先不是分支限界法的搜索方式。答案:正确二分搜索算法是利用分治策略实现的算法。答案:正确背包问题不能使用贪心法解决。答案:错误单源最短路径问题不能使用贪心法解决。答案:错误时间复杂度低是衡量一个算法好坏的标准。答案:正确归并排序不可以使用分治法求解。答案:错误拉斯维加斯算法有时找不到问题的解。答案:正确舍伍德算法有时候找不到问题的解。答案:错误NP问题都是不可能解决的问题答案:错误P类问题包含在NP类问题中。答案:正确NP类问题包含在P类问题中。答案:错误NP完全问题是P类问题的子集答案:错误112.蒙特卡罗算法是概率算法的一种答案:正确113.蒙特卡罗算法是贪心算法的一种答案:错误114.蒙特卡罗算法是回溯算法的一种答案:错误115.动态规划算法不是随机化算法答案:正确116.最优子结构性质是贪心算法与动态规划算法的共同点答案:正确117.矩阵连乘问题的算法可由动态规划算法来设计实现答案:正确Strassen矩阵乘法是利用分治策略实现的算法答案:正确Strassen矩阵乘法是利用贪心法实现的算法答案:错误120.贪心选择性质是贪心算法的基本要素答案:正确121.以深度优先方式系统搜索问题解的算法称为回溯算法答案:正确122.算法分析的两个主要方面是时间复杂度和空间复杂度分析答案:正确123.实现最大子段和利用的算法是动态规划法答案:正确124.实现最大子段和利用的算法是贪心法答案:错误125.实现最大子段和利用的算法是回溯法答案:错误126.广度优先是分支限界算法的一种搜索方式答案:正确127.广度优先是回溯算法的一种搜索方式答案:错误128.广度优先是贪心算法的一种搜索方式答案:错误129.舍伍德算法是概率算法的一种答案:正确130.舍伍德算法是贪心算法的一种。答案:错误131.舍伍德算法是回溯算法的一种。答案:错误132.实现最长公共子序列利用的算法是动态规划法。答案:正确133.计算机算法指的是解决问题的方法和过程。答案:正确134.根据排序元素所在位置的不同,排序分排序和外排序。答案:正确135.根据排序元素所在位置的不同,排序分首排序和尾排序。答案:错误136.算法必须具备输入、输出和有穷性、确定性和可行性等5个特性。答案:正确137.算法必须具备输入、输出和易读性、稳定性和安全性等5个特性。答案:错误138.与分治法不同的是,适合于用动态规划求解的问题经分解得到的子问题往往不是相互独立的139.与分治法不同的是,适合于用动态规划求解的问题往往是相互独立的答案:错误140.二分搜索算法的基本思想是将n个元素分成个数大致相同的两半,取2巾/2]与x进行比较:如果*<2巾/2],则只要在数组a的左半部继续搜索x答案:正确141.二分搜索算法的基本思想是将n个元素分成个数大致相同的两半,取2巾/2]与x进行比较:如果*>2巾/2],则只要在数组a的左半部继续搜索x答案:错误142.算法必须具备输入、输出和可执行性、可移植性和可扩充性等5个特性。答案:错误143.适用动态规划的问题必须满足最优化原理和无后效性。答案:正确144.适用动态规划的问题必须满足最优化原理和后效性。答案:错误145.二分查找只适用于顺序存储结构。答案:正确146.二分查找只适用于链式存储结构。答案:错误147.应用分治法的两个前提是问题的可分性和解的可归并性。答案:正确148.应用分治法的两个前提是问题的可分性和解的复杂性。答案:错误.对于口个元素的排序问题。n=2时只要作1次比较即可排好序。答案:正确.对于口个元素的排序问题。n=2时要作2次比较即可排好序。答案:错误.分治法所能解决的问题应具有的关键特征是利用该问题分解出的子问题的解可以合并为该问题的解。答案:正确.分治法所能解决的问题应具有的关键特征是该问题的规模缩小到一定的程度就可以容易地解决。答案:错误153.直接或间接的调用自身的算法称为递归算法。答案:正确154.直接或间接的调用自身的算法称为动态规划算法。答案:错误.当上下限表示相等时我们使用0表示法来描述算法代价。答案:正确.当上下限表示相等时我们使用大0表示法来描述算法代价。答案:错误.递归通常用栈来实现。答案:正确.递归通常用队列来实现。答案:错误.分治法的设计思想是将一个难以直接解决的大问题分割成规模较小的子问题分别解决子问题最后将子问题的解组合起来形成原问题的解。这要求原问题和子问题的问题规模不同,问题性质相同。答案:正确.0/1背包问题不能用贪心算法求解。答案:正确.可以由多项式时间算法求解的问题是易处理的。答案:正确.可以由多项式时间算法求解的问题是难处理的。答案:错误.需要超过多项式时间算法求解的问题是不能处理的。答案:错误.递归通常用数组来实现。答案:错误.哈密尔顿回路问题是典型的NP完全问题。答案:正确166.排序问题是典型的NP完全问题。答案:错误167.算法分析需要对算法需要多少计算时间和存储空间作定量分析。答案:正确168.用数量级形式表示算法的执行时间称为算法的时间复杂度。答案:正确169.用数量级形式表示算法的执行时间称为算法的空间复杂度。答案:错误170.最坏情况下,顺序查找的时间复杂度为。(口)。答案:正确171.最坏情况下,折半查找的时间复杂度为0(10。加。答案:正确172.合并排序的基本运算是把两个或多个有序序列合并成一个有序序列答案:正确173.最优子结构是动态规划算法的基本要素之一。答案:正确174.快速排序算法是基于分治策略的一种排序算法。答案:正确175.快速排序算法是基于回溯的一种排序算法。答案:错误176.快速排序算法是基于贪心法的一种排序算法。答案:错误177.贪心法通常以自顶向下的方式求解最优解。答案:正确178.分治法通常以自顶向下的方式求解最优解。答案:错误179.回溯法通常以自顶向下的方式求解最优解。答案:错误180.不断回头寻找目标的方法称为回溯法。181.不断回头寻找目标的方法称为概率算法。答案:错误182.不断回头寻找目标的方法称为贪心法。答案:错误183.拉斯维加斯算法找到的解一定是正确的。答案:正确184.拉斯维加斯算法找到的解正确与否不确定。答案:错误0记号在算法复杂性的表示法中表示紧致界。答案:正确0记号在算法复杂性的表示法中表示上界。答案:错误0记号在算法复杂性的表示法中表示下界。答案:错误188.一个算法是对特定问题求解的一种描述,它是指令的有限序列。答案:正确189.一个递归算法必须包括终止条件和递归部分。答案:正确190.栈和队列的共同点是只允许在端点处插入和删除元素。答案:正确191.排序趟数与原始序列有关的排序方法是冒泡排序法。答案:正确192.栈和队列的共同点都是先进先出。答案:错误193.栈和队列的共同点都是先进后出。答案:错误194.排序趟数与原始序列有关的排序方法是选择排序法。答案:错误在算法的三种情况下的复杂性中,可操作性最好且最有实际价值的是最坏情况下的时间复杂度。答案:正确在算法的三种情况下的复杂性中,可操作性最好且最有实际价值的是最好情况下的时间复杂度。答案:错误若一个算法的时间复杂度用丁(口)表示,其中口的含义是问题规模。答案:正确198.合并排序法的基本思想是:将待排序元素分成大小大致相同的2个子集合,分别对每个子集合进行排序,最终将排好序的子集合合并成为所要求的排好序的集合。答案:正确选择题:.二分搜索算法是利用(A)实现的算法。选项A.分治策略选项B.动态规划法选项C.贪心法选项D.回溯法答案:.回溯法解旅行售货员问题时的解空间树是(B)。选项A.子集树选项B.排列树选项C.深度优先生成树选项D.广度优先生成树答案:.下列算法常以自底向上的方式求解最优解的是(B)。选项A.备忘录法选项B.动态规划法选项C.贪心法选项D.回溯法答案:.下面不是分支界限法搜索方式的是(D)。选项A.广度优先选项B.最小耗费优先选项C.最大效益优先选项D.深度优先5.采用贪心算法的最优装载问题的主要计算量在于将集装箱依其重量从小到大排序,故算法的时间复杂度(B)。A、O()B、O(nlogn)C、O()D、O(n).分支限界法求解最大团问题时,活结点表的组织形式是(B)。人、最小堆8、最大堆C、栈口、数组7、下面问题(B)不能使用贪心法解决。A单源最短路径问题BN皇后问题C最小花费生成树问题D背包问题答案:.下列算法中不能解决0/1背包问题的是(A)。A贪心法B动态规划C回溯法D分支限界法答案:.背包问题的贪心算法所需的计算时间为(B)。A、O(n)B、O(nlogn)C、O()D、O(n)答案:.二分搜索算法是利用(A)实现的算法。A.分治策略B、动态规划法5贪心法口、回溯法答案:.下列不是动态规划算法基本步骤的是(B)。人、找出最优解的性质8、构造最优解^算出最优解□、定义最优解答案:12.最大效益优先是(A)的一种搜索方式。人、分支界限法B、动态规划法5贪心法D.回溯法答案:13、在下列算法中有时找不到问题解的是(B)。人、蒙特卡罗算法8、拉斯维加斯算法5舍伍德算法口、数值概率算法答案:.下列算法常以自底向上的方式求解最优解的是(B)。A、备忘录法B、动态规划法5贪心法口、回溯法答案:.下列算法常以自底向上的方式求解最优解的是(B)。A、备忘录法B、动态规划法5贪心法口、回溯法答案:15、衡量一个算法好坏的标准是(C)。A运行速度快B占用空间少C时间复杂度低D代码短答案:16、以下不可以使用分治法求解的是(D)。人、棋盘覆盖问题B、选择问题C、归并排序D、0/1背包问题答案:17.实现循环赛日程表利用的算法是(A)人、分治策略B、动态规划法5贪心法D.回溯法答案:18、下列随机算法中运行时有时候成功有时候失败的是(C)A数值概率算法B舍伍德算法C拉斯维加斯算法D蒙特卡罗算法答案:19.下面不是分支界限法搜索方式的是(D)。A、广度优先8、最小耗费优先5最大效益优先口、深度优先答案:.下列算法常以深度优先方式系统搜索问题解的是(D)。A、备忘录法B、动态规划法5贪心法口、回溯法答案:.备忘录方法是那种算法的变形。(B)。人、分治法B、动态规划法5贪心法口、回溯法答案:22.哈弗曼编码的贪心算法所需的计算时间为(B)。A、O(n)B、O(nlogn)C、O()D、O(n)答案:23.最长公共子序列算法利用的算法是(B)人、分支界限法B、动态规划法5贪心法D.回溯法答案:24.实现棋盘覆盖算法利用的算法是(A)。八、分治法B、动态规划法5贪心法D.回溯法答案:.下面是贪心算法的基本要素的是(C)。A、重叠子问题8、构造最优解5贪心选择性质□、定义最优解.回溯法的效率不依赖于下列哪些因素(D)。满足显约束的值的个数C.计算限界函数的时间计算约束函数的时间D.确定解空间的时间27.下面哪种函数是回溯法中为避免无效搜索采取的策略(B)。A递归函数B.剪枝函数^随机数函数口.搜索函数28、下面关于NP问题说确的是(B)。A.NP问题都是不可能解决的问题B.P类问题包含在NP类问题中CNP完全问题是P类问题的子集D.NP类问题包含在P类问题中29、蒙特卡罗算法是(B)的一种。分支界限算法概率算法贪心算法回溯算法答案:.下列哪一种算法不是随机化算法(C)。蒙特卡罗算法拉斯维加斯算法动态规划算法口舍伍德算法答案:.(D)是贪心算法与动态规划算法的共同点。A、重叠子问题8、构造最优解5贪心选择性质口、最优子结构性质答案:32.矩阵连乘问题的算法可由(B)设计实现。人、分支界限算法B、动态规划算法C、贪心算法口、回溯算法答案:33、Strassen矩阵乘法是利用(A)实现的算法。人、分治策略B、动态规划法5贪心法口、回溯法答案:34、使用分治法求解不需要满足的条件是(A)。A子问题必须是一样的B子问题不能够重复C子问题的解可以合并D原问题和子问题使用相同的方法求解35、回溯法搜索状态空间树是按照(0的顺序。A中序遍历B广度优先遍历C深度优先遍历D层次优先遍历答案:36、实现合并排序利用的算法是(A)人、分治策略B、动态规划法5贪心法D.回溯法答案:37、下列是动态规划算法基本要素的是(D)人、定义最优解8、构造最优解^算出最优解口、子空间重叠性质答案:38.采用广度优先策略搜索的算法是(A)人、分支界限法B、动态规划法5贪心法口、回溯法答案:39、在下列算法中得到的解未必正确的是(A)人、蒙特卡罗算法8、拉斯维加斯算法5舍伍德算法口、数值概率算法答案:40.实现大整数的乘法是利用的算法(C)人、贪心法B、动态规划法^分治策略口、回溯法答案:.0-1背包问题的回溯算法所需的计算时间为(A)A、O(n)B、O(nlogn)C、O()D、O(n)答案:.贪心算法与动态规划算法的主要区别是(B)人、最优子结构8、贪心选择性质^构造最优解□、定义最优解答案:.实现最大子段和利用的算法是(B)。人、分治策略B、动态规划法5贪心法口、回溯法答案:.优先队列式分支限界法选取扩展结点的原则是(C人、先进先出8、后进先出^结点的优先级口、随机答案:45、广度优先是(A)的一种搜索方式。人、分支界限算法B、动态规划法C、贪心算法口、回溯算法答案:46、舍伍德算法是(B)的一种人、分支界限算法8、概率算法C、贪心算法口、回溯算法答案:47、在下列算法中有时找不到问题解的是(B)人、蒙特卡罗算法8、拉斯维加斯算法5舍伍德算法口、数值概率算法答案:48下列哪一种算法是随机化算法(D)。贪心算法回溯法动态规划算法舍伍德算法答案:49.一个问题可用动态规划算法或贪心算法求解的关键特征是问题的(B)。A、重叠子问题8、最优子结构性质5贪心选择性质□、定义最优解答案:.以深度优先方式系统搜索问题解的算法称为(D)。人、分支界限算法8、概率算法C、贪心算法口、回溯算法答案:.实现最长公共子序列利用的算法是(B)。人、分治策略B、动态规划法5贪心法口、回溯法.算法分析的两个主要方面是(A)。空间复杂度和时间复杂度正确性和简单性可读性和文档性数据复杂度和程序复杂度.计算机算法指的是(C)。计算方法排序方法解决问题的方法和过程调度方法56.多阶段决策问题就是要在可以选择的那些策略中间选取一个(A)策略使在预定的标准下达到最好的效果。最优最差平衡任意.根据排序元素所在位置的不同,排序分(A)。排序和外排序首排序和尾排序顺序排序和逆序排序堆排序和栈排序.算法必须具备输入、输出和(B)等5个特性。可执行性、可移植性和可扩充性可行性、确定性和有穷性确定性、有穷性和稳定性易读性、稳定性和安全性.与分治法不同的是,适合于用动态规划求解的问题(A)。经分解得到子问题往往不是互相独立的经分解得到子问题往往是互相独立的^经分解得到子问题往往是互相交叉的D.经分解得到子问题往往是任意的.二分搜索算法的基本思想是将n个元素分成个数大致相同的两半,取2巾/2]与x进行比较:如果(A),则只要在数组a的左半部继续搜索x。x<a[n/2]x=a[n/2]x>a[n/2]x>=a[n/2].活动安排问题就是在所给的活动集合中,选出(C)的相容活子集。最小任意最大一个.在对问题的解空间树进行搜索的方法中一个活结点最多有一次机会成为活结点的是(B)。回溯法分支限界法回溯法和分支限界法回溯法求解子集树问题.适用动态规划的问题必须满足(D)。最优化原理无前效性最优化原理和后效性最优化原理和无后效性.算法的每种运算必须要有确切的定义不能有二义性,以下符合算法确定性运算的是(B)。A.5/08.将6成7与*相加^未赋值变量参与运算D.f(n)=f(n-1)+2,F(1)=10,n为自然数.直接或间接的调用自身的算法称为(B)。贪心算法递归算法迭代算法动态规划算法.二分查找只适用(B)存储结构。堆顺序任意顺序栈.应用分治法的两个前提是(A)。问题的可分性和解的可归并性问题的可分性和解的存在性问题的复杂性和解的可归并性问题的可分性和解的复杂性68.优先队列的分支限界法将活结点表组织成一个优先队列,并按优先队列中规定的结点优先级选取优先级最高的下一个结点成为当前扩展结点。优先队列中规定的结点优先级常用一个与该结点相关的数值口来表示。结点优先级的高低与口值大小相关,根据问题的不同情况,采用(C)来描述优先队列。先进先出队列后进先出的栈最大堆或最小堆随机序列69.阶乘函数用递归定义Publicstaticintfactorial(intn){if(n==0)return1;return(B):}A.n*factorial(n)n*factorial(n-1)n*factorial(n-2)n*factorial(n+1).(B)能够求得问题的解但却无法有效地判定解的正确性。数值概率算法蒙特卡罗算法拉斯维加斯算法舍伍得算法.对于口个元素的排序问题。口=2时只要作(C)次比较即可排好序。3214.一般地讲,当一个问题的所有子问题都至少要解一次时,用动态规划算法和备忘录算法相比:(B)。效果一样动态规划效果好备忘录方法效果好无法判断哪个效果好.分支限界法与回溯法都是在问题的解空间树丁上搜索问题的解,二者(B)。求解目标不同搜索方式相同求解目标不同搜索方式也不同求解目标相同搜索方式不同求解目标相同搜索方式也相同.递归算法不能适用以下场合(D)。数据的定义形式按递归定义数据之间的关系即数据结构按递归定义问题解法按递归算法实现概率问题.若当子问题之间包含公共的子子问题时,则分治法要做许多不必要的工作,重复地解公共的子问题,此时一般用(A)法较好。动态规划分治贪心概率.分治法所能解决的问题应具有的关键特征是(C)。该问题的规模缩小到一定的程度就可以容易地解决该问题可以分解为若干个规模较小的相同问题利用该问题分解出的子问题的解可以合并为该问题的解该问题所分解出的各个子问题是相互独立的.对于货箱装船问题根据贪心策略首先选择(A)的货箱然后选(A)的货箱如此下去直到所有货箱均装上船或船上不能再容纳其他任何一个货箱。最轻次轻最重次重最轻次重口.最重次轻.用回溯法解口后问题时,用完全口叉树表示解空间。可行性约束口跄6剪去不满足行、列和斜线约束的子树,口跄0中的if判断条件应为(A)。(Math.abs(k-j)==Math.abs(x[j]-x[k]))||x[j]==x[k])(Math.abs(k-j)==Math.abs(x[j]-x[k]))(x[j]-x[k])以上都不正确79.分支限界法的搜索策略是:在扩展结点处,先生成其(D)儿子结点(分支),然后再从当前的活结点表中选择下一个扩展对点。为了有效地选择下一扩展结点,以加速搜索的进程,在每一活结点处,计算一个函数值(限界),并根据这些已计算出的函数值,从当前活结点表中选择一个最有利的结点作为扩展结点,使搜索朝着解空间树上有最优解的分支推进,以便尽快地找出一个最优解。一个二个任意多个所有的.能够用动态规划解决的问题还有一个显著特征(D)这个性质并不是动态规划适用的必要条件,但是如果该性质无法满足,动态规划算法同其他算法相比就不具备优势。子问题的可求解性子问题的独立性子问题的可合并性子问题的重叠性.在任何一个2k*2k的棋盘覆盖中,用到的1型骨牌个数恰为(A)。(4k—1)/3(4k—1)/2(2k—1)/3(2k—1)/2.以8计^匕旅行路线问题为例,动态规划的时间复杂度为(C)。O(n)O(n!)O(n2)O(n3).一个算法应该包含如下几条性质除了(A)。人二义性8.有限性^正确性D.可终止性.解决一个问题通常有多种方法。若说一个算法“有效”是指(D)。A.这个算法能在一定的时间和空间资源限制将问题解决B.这个算法能在人的反应时间将问题解决C.这个算法比其他已知算法都更快地将问题解决D.A和C.当输入规模为n时算法增长率最小的是(B)。5n20log2n2n23nlog3n.渐进算法分析是指(B)。算法在最佳情况、最差情况和平均情况下的代价当规模逐步往极限方向增大时对算法资源开销“增长率”上的简化分析数据结构所占用的空间在最小输入规模下算法的资源代价.当上下限表达式相等时我们使用下列哪种表示法来描述算法代价?(C人大0表示法B.大Q表示法C.㊀表示法D.小。表示法88.采用“顺序搜索法”从一个长度为N的随机分布数组中搜寻值为K的元素,以下对顺序搜索法分析正确的是(B)。人最佳情况、最差情况和平均情况下顺序搜索法的渐进代价都相同8.最佳情况的渐进代价要好于最差情况和平均情况的渐进代价C最佳情况和平均情况的渐进代价要好于最差情况的渐进代价口.最佳情况的渐进代价要好于平均情况的渐进代价而平均情况的渐进代价要好于最差情况的渐进代价.递归通常用(C)来实现。有序的线性表队列栈数组.分治法的设计思想是将一个难以直接解决的大问题分割成规模较小的子问题分别解决子问题最后将子问题的解组合起来形成原问题的解。这要求原问题和子问题(C)。A问题规模相同,问题性质相同B问题规模相同,问题性质不同C问题规模不同,问题性质相同D问题规模不同,问题性质不同.在寻找n个元素中第卜小元素问题中如快速排序算法思想运用分治算法对口个元素进行划分如何选择划分基准下面(D)答案解释最合理。人随机选择一个元素作为划分基准8.取子序列的第一个元素作为划分基准C.用中位数的中位数方法寻找划分基准口.以上皆可行。但不同方法算法复杂度上界可能不同92.对于01背包问题和背包问题的解法下面(C)答案解释正确。人01背包问题和背包问题都可用贪心算法求解01背包问题可用贪心算法求解但背包问题则不能用贪心算法求解01背包问题不能用贪心算法求解但可以使用动态规划或搜索算法求解而背包问题则可以用贪心算法求解口.因为01背包问题不具有最优子结构性质所以不能用贪心算法求解93.关于回溯搜索法的介绍下面(D)是不正确描述。人回溯法有“通用解题法”之称它可以系统地搜索一个问题的所有解或任意解8.回溯法是一种既带系统性又带有跳跃性的搜索算法C.回溯算法在生成解空间的任一结点时先判断该结点是否可能包含问题的解如果肯定不包含则跳过对该结点为根的子树的搜索逐层向祖先结点回溯口.回溯算法需要借助队列这种结构来保存从根结点到当前扩展结点的路径.关于回溯算法和分支限界法以下(A)是不正确描述。人回溯法中每个活结点只有一次机会成为扩展结点B分支限界法中活结点一旦成为扩展结点就一次性产生其所有儿子结点在这些儿子结点中那些导致不可行解或导致非最优解的儿子结点被舍弃其余儿子加入活结点表中C回溯法采用深度优先的结点生成策略口分支限界法采用广度优先或最小耗费优先最大效益优先的结点生成策略.优先队列通常用以下(B)数据结构来实现。A栈BT^队列口.二叉查找树.在分支限界算法中根据从活结点表中选择下一扩展结点的不同方式可有几种常用分类,以下(D)描述最为准确。A采用FIFO队列的队列式分支限界法8采用最小值堆的优先队列式分支限界法C采用最大值堆的优先队列式分支限界法口以上都常用针对具体问题可以选择采用其中某种更为合适的方式.对布线问题以下(C)是不正确描述。A布线问题的解空间是一个图B可以对方格阵列四周设置围墙,即增设标记的附加方格的预处理,使得算法简化对边界的判定C采用广度优先的标号法找到从起点到终点的布线方案这个方案如果存在的话不一定是最短的口采用先人先出的队列作为活结点表以,终点匕为扩展结点或活结点队列为空作为算法结束条件.下述表达不正确的是(D)。n2/2+2n的渐进表达式上界函数是。(2n)n2/2+2n的渐进表达式下界函数是Q(2n)Clogn3的渐进表达式上界函数是^(logn)D.logn3的渐进表达式下界函数是0(n3)99.当输入规模为n时,算法增长率最大的是(A)。A.5nB.20log2nC.2n2D.3nlogn100.丁(口)表示当输入规模为口时的算法效率,以下算法效率最优的是(C)。A.T(n)=T(n-1)+1,T(1)=1B.T(n)=2n2T(n)=T(n/2)+1,T(1)=1T(n)=3nlog2n101.有9个村庄,其坐标位置如下表所示:i123456789x(i)123456789y(i)123456789现在要盖一所邮局为这9个村庄服务,请问邮局应该盖在(C)才能使邮局到9个村庄的距离和最短。A.(4.5,0)B.(4.5,4.5)C.(5,5)D.(5,0).n个人拎着水桶在一个水龙头前面排队打水水桶有大有小水桶必须打满水水流恒定。如下(A)说法不正确A让水桶大的人先打水可以使得每个人排队时间之和最小B.让水桶小的人先打水可以使得每个人排队时间之和最小^让水桶小的人先打水在某个确定的时间t可以让尽可能多的人打上水口.若要在尽可能短的时间n个人都打完水按照什么顺序其实都一样.对于含有n个元素的子集树问题,最坏情况下其解空间的叶结点数目为(B)。n!2n2n+i—1D.工n!/i!i=1104.以下关于判定问题难易处理的叙述中正确的是(C)人可以由多项式时间算法求解的问题是难处理的8.需要超过多项式时间算法求解的问题是易处理的^可以由多项式时间算法求解的问题是易处理的口.需要超过多项式时间算法求解的问题是不能处理的.回溯法在解空间树丁上的搜索方式是(A)深度优先广度优先最小耗费优先活结点优先.设£3),。3)是定义在正数集上的正函数,如果存在正的常数C和自然数N0,使得当N>N0时有f(N)<Cg(N),则称函数f(N)当N充分大时有上界。3),记作f(N)=O(g(N)),即f(N)的阶(A)。3)的阶。不高于不低于等价于逼近.以下(C)不能在线性时间完成排序A.计数排序8.基数排序0堆排序口.桶排序.以下(A)不一定得到问题的最优解A.贪心算法8.回溯算法^分支限界法D.动态规划法.下列不属于一个好的算法应具有的特性的是(C)。正确性简明性无限性最优性.算法分析是(C)。A.将算法用某种程序设计语言恰当地表示出来8.在抽象数据集合上执行程序,以确定是否会产生错误的结果对算法需要多少计算时间和存储空间作定量分析证明算法对所有可能的合法输入都能算出正确的答案111.学校要举行运动会,请你设计一个能够对运动员分数自动排序的软件,如果要设计此软件,以下最好的方法和步骤是(C)。分析问题,编写程序,设计算法,调试程序设计算法,编写程序,提出问题,调试程序提出问题,设计算法,编写程序,调试程序设计算法,提出问题,编写程序,调试程序112.考虑背包问题:n=6,M=10,V(1:6)=(15,59,21,30,60,5),W(1:6)=(1,5,2,3,6,1)。该问题的最大效益值为(C)。101110115D.120113.考虑背包问题:n=6,M=10,V(1:6)=(15,59,21,30,60,5),W(1:6)=(1,5,2,3,6,1)。若把它看作是0/1背包问题,则该问题的最大效益值为(B)。101110115D.120114.我最小生成树的算法Kruskal的时间复杂度为(D)。O(n2)O(mlogn)C.O(nlogm)D.O(mlogm).算法与程序的区别在于算法具有(C)。能行性确定性有穷性输入和输出.设A[1..60]={11,12,…,70}。算法折半查找在人上搜索*=33、7、70、77时执行的元素比较次数分别为a、b、c、d,则(C)。a<b<c<da>b=c=da<b=c=da<c<b=d算法直接插入排序在A[1..8]={45,33,24,45,12,12,24,12}上运行时执行的元素比较次数为(D)。1428722voidhanoi(intn,inta,intb,intc){if(n>0){hanoi(n-1,a,c,b);move(a,b);hanoi(n-1,c,b,a);}}上述算法的时间复杂度为(A)。O(2n)O(nlogn)9(n!)9(nn)当一个确定性算法在最坏情况下的计算复杂性与其在平均情况下的计算复杂性有较大差别时,可以使用(B)来消除或减少问题的好坏实例间的这种差别。数值概率算法舍伍德算法拉斯维加斯算法蒙特卡罗算法120.当输入规模为n时,算法增长率最快的是(C)。A.12nB.100log2n2n23nlog3n121.关于0-1背包问题,以下描述正确的是(D)。可以使用贪心算法找到最优解能找到多项式时间的有效算法使用教材介绍的动态规划方法可求解任意0-1背包问题对于同一背包与相同的物品,做背包问题取得的总价值一定大于等于做0-1背包问题。122.设有口项独立的作业{1,2,…,n},由m台相同的机器加工处理。作业》所需要的处理时间为八约定:任何一项作业可在任何一台机器上处理,但未完工前不准中断处理;任何作业不能拆分更小的子作业。多机调度问题要求给出一种调度方案,使所给的口个作业在尽可能短的时间由m台机器处理完(口>团)。对于多级调度问题,使用哪种贪心策略比较合适(B)。作业从小到大依次分配给空闲的机器作业从大到小依次分配给空闲的机器每个机器分配一样的作业数使用以上几种贪心策略都能找到最优解,所以都合适123.使用二分搜索算法在1000个有序元素表中搜索一个特定元素,在最坏情况下,搜索总共需要比较的次数为(A)。10115001000124.用数量级形式表示算法的执行时间称为算法的(A)。时间复杂度空间复杂度处理器复杂度D.通信复杂度.下面哪个问题不是典型的NP完全问题(D)。m-着色问题旅行商问题哈密尔顿回路问题排序问题.顺序查找的时间复杂度为(A)。O(n)O(logn)O(n2)D.O(nlogn).折半查找的时间复杂度为(B)。O(n)O(logn)O(n2)D.O(nlogn).算法的复杂性有时间复杂性和(C)复杂性之分。处理器复杂性通信复杂性空间复杂性存储复杂性.算法的复杂性有空间复杂性和(C)复杂性之分。处理器复杂性通信复杂性时间复杂性存储复杂性.算法是由若干条指令组成的有穷序列,且要满足输入、输出、确定性和有限性四条性质。其中算法的“确定性”是指组成算法的每条(B)是清晰的,无歧义的。程序指令语句语句块.(C)的基本运算是把两个或多个有序序列合并成一个有序序列。快速排序希尔排序合并排序D.堆排序.解决0/1背包问题可以使用动态规划,回溯法,分支限界法。其中不需要排序的是(A)。动态规划回溯法分支限界法以上3种方法都需要排序.解决0/1背包问题时需要排序的方法是回溯法和(B)。动态规划分支限界法贪心法线性规划.下面哪项是动态规划算法基本要素之一(D)。人、定义最优解8、构造最优解^算出最优解口、最优子结构.快速排序算法是基于(A)的一种排序算法。分治策略贪心回溯动态规划.(C)是贪心算法可行的第一个基本要素,也是贪心算法与动态规划算法的主要区别。A、重叠子问题8、最优子结构5贪心选择性质□、定义最优解.如果无向连通图6中不包含任何关节点,则称该图6为(A)。双连通图单连通图强连通图弱连通图138.使用剪枝函数的深度优先生成状态空间树中结点的求解方法称为(D)。动态规划分支限界法贪心法回溯法.回溯法的算法框架按照问题的解空间一般分为子集树算法框架和(A)算法框架。人排列树8二叉树C.B树D.B+树.下列算法常以自顶向下的方式求解最优解的是(C)。分治法动态规划法贪心法回溯法.哈夫曼编码可利用(C)算法实现。人、分治策略B、动态规划法5贪心法D.回溯法.在对问题的解空间树进行搜索的方法中一个活结点有多次机会成为活结点的是(A)。回溯法分支限界法回溯法和分支限界法动态规划143、始皇吞并六国使用的远交近攻逐个击破的连横策略采用了以下哪种算法思想(B)。A、递归8、分治5迭代D、模拟。144、FIFO是(A)的一搜索方式。人、分支界限法B、动态规划法5贪心法D.回溯法145、投点法是(B)的一种。人、分支界限算法8、概率算法C、贪心算法口、回溯算法146、若线性规划问题存在最优解它一定不在(C)。人可行域的某个顶点上8可行域的某条边上C可行域部口以上都不对147、在一般输入数据的程序里输入多多少少会影响到算法的计算复杂度,为了消除这种影响可用(B)对输入进行预处理。人、蒙特卡罗算法8、拉斯维加斯算法5舍伍德算法口、数值概率算法148、若1是一个NP完全问题L经过多项式时间变换后得到问题l则1是(A)。A、P类问题B、NP难问题C、NP完全问题D、P类语言.不断回头寻找目标的方法称为(C)。动态规划贪心法回溯法概率算法.拉斯维加斯算法找到的解一定是(B)。不确定的正确的C.不正确的口.局部最优的.记号在算法复杂性的表示法中表示(C)。上界下界紧致界以上说法都不对.一个无向连通图不是双向连通图的充要条件是图中存在(B)。回路关节点最大团最小团153.一个算法是对特定问题求解的一种描述,它是(A)。指令的有限序列程序的有限序列语句的有限序列代码的有限序列154.矩阵乘法如下:for(i=0;i<n;i++)for(j=0;j<n;j++){C[i][j]=0;for(k=0;k<n;k++)C[i][j]+=a[i][k]*b[k][j];}它的渐近时间复杂度为(B)。O(n2)O(n3)O(n)O(n4).二分搜索过程的算法行为可以用一棵(B)来描述。二叉排序树二叉判定树子集树排列树.用贪心法求解背包问题时,为了使收益最大化要选择(A)的物品装入背包。单位重量收益最大收益最大重量最大重量最小.一个递归算法必须包括(B)。递归部分终止条件和递归部分迭代部分终止条件和迭代部分.有六个元素6,5,4,3,2,1的顺序进栈,则下列哪一个不是合法的出栈序列(C)。543612453126346521234156.栈和队列的共同点是(C)。都是先进先出都是先进后出只允许在端点处插入和删除元素没有共同点160.若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是()。91115不确定.排序趟数与原始序列有关的排序方法是(C)排序法。A.插入B.选择C.冒泡D.快速.如果给定权值总数有口个,则其哈夫曼树的结点总数为(D)。不确定2n2n+12n-13.一个栈的输入序列为123…口,若输出序列的第一个元素是"则输出第》(1<i<n)个元素是(B)。不确定n-i+1in-i164.下列序列中,(C)是执行第一趟快速排序后所得的序列。A.[68,11,18,69][23,93,73][68,11,69,23][18,93,73][93,73][68,11,69,23,18][68,11,69,23,18][93,73]165.下列哪个问题不能用贪心法求解?(C)人哈夫曼编码问题8.单源最短路径问题C.0-1背包问题口.最小生成树问题.下列随机算法一定有解但解不一定正确的是(C)。SherwoodLasVegasMonteCarlo口.三者都不是.在算法的三种情况下的复杂性中,可操作性最好且最有实际价值的是(B)情况下的时间复杂度。最好最坏平均以上都不正确.快速排序算法的性能取决于(A)。划分的对称性数据的原始序列随机选择策略以上都不正确.回溯法在问题的解空间树中,按(B)策略,从根节点出发搜索解空间树。广度优先深度优先随机以上说法都不对.大符号用来描述增长率的下限,这个下限的阶越(A),结果就越有价值。高低和具体问题有关以上都不正确.设计动态规划算法的步骤为:(1)找出最优解的性质,并刻画其结构特征。(2)(B)。(3)以自底向上的方式计算出最优值。(4)计算最优值得到的信息,构造最优解。非递归的定义最优值递归的定义最优值迭代的定义最优值递推的定义最优值172.设计动态规划算法的步骤为:(1)找出最优解的性质,并刻画其结构特征。(2)递归的定义最优值。(3)(A)。(4)计算最优值得到的信息,构造最优解。以自底向上的方式计算出最优值以自顶向下的方式计算出最优值迭代的方式计算出最优值递推的方式算出最优值.最优二叉搜索树即是(A)的二叉搜索树。最小平均查找时间最小最坏查找时间最小平均存储空间最小最坏存储空间.当(a1,a2,a3,a4,a5,a6)=(-2,11,-4,13,-5,-2)时,最大子段和为(C)。242220D.15.9n2+10n的渐近表达式是(A)。O(n2)O(n3)O(n)O(n4).下面程序段的时间复杂度是(C)。for(i=0;i<n;i++)for(j=0;j<n;j++)O(n)O(n3)O(n2)O(n4)177.快速排序算法是基于分治策略的一个算法,其基本思想是,对于输入的子数组a[p:r],按以下三个步骤进行排序:(A)。分解、递归求解、合并递归求解、分解、合并合并、递归求解、分解分解、合并、递归求解178.最优装载问题可用贪心算法求解,采用(C)先装的贪心选择策略,可产生最优装载问题的最优解。重量最重者单位重量收益大重量最轻者收益最大.写出下列炉)的渐进性态,若^)=勺,C0为常数,则f(n)=(A)。O(1)O(n)O(n2)O(n3).写出下列改口)的渐进性态,若f(n)=3n+2,则f(n)=(B)。O(1)O(n)O(n2)O(n3).写出下列改口)的渐进性态,若f(n)=6*2n+n,则f(n)=(B)。O(1)O(2n)O(n2)O(n3).若一个算法的时间复杂度用丁⑺表示,其中口的含义是(A)。问题规模语句条数循环层数函数数量.背包问题可获得最优解的输入是按(B)。重量密度排序价值密度排序单位重量收益大小排序重量大小排序4.合并排序法的基本思想是:将待排序元素分成大小大致相同的(C)个子集合,分别对每个子集合进行排序,最终将排好序的子集合合并成为所要求的排好序的集合。4325.二分搜索算法的基本思想是将n个元素分成个数大致相同的两半,取2巾/2]与x进行比较:如果(C ),则只要在数组a的右半部继续搜索X。x<a[n/2]X=a[n/2]x>a[n/2]x>=a[n/2].当问题规模n趋向于无穷大时,(B)的数量级(阶)称为算法的渐进时间复杂度。空间复杂度时间复杂度冗余度迭代次数.通常用来表示时间算法的有以下六种多项式:0(1),0(m),O(log2n),O(n*O(n),O(nlog2n),按从小到大的顺序排列是(A)。O(1)<O(logn)<O(n)<O(nlogn)<O(n2)<O(n3)22O(1)<O(n)<O(logn)<O(nlogn)<O(n2)<O(n3)22O(1)<O(log2n)<O(n)<O(n2)<O(nlog2n)<O(n3)O(1)<O(n)<O(log2n)<O(nlog2n)<O(n2)<O(n3).贪心方法是一种求(C)的方法。最小解最大解最优解局部最优解.0干%))=0(即))其中P是一个(A)。正的常数负的常数不确定以上说法都不对.当问题规模n趋向于无

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论