首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读下列函数说明,将应填入(n)处的字句写在答卷纸的对应栏内。 【函数1说明】 函数compare(SqList A,SqList B)的功能是:设A=(al,…,am)和B=(b1,…,bn)均为顺序表,“比较”两个顺序表A和B的大小。设A’
阅读下列函数说明,将应填入(n)处的字句写在答卷纸的对应栏内。 【函数1说明】 函数compare(SqList A,SqList B)的功能是:设A=(al,…,am)和B=(b1,…,bn)均为顺序表,“比较”两个顺序表A和B的大小。设A’
admin
2009-02-15
26
问题
阅读下列函数说明,将应填入(n)处的字句写在答卷纸的对应栏内。
【函数1说明】
函数compare(SqList A,SqList B)的功能是:设A=(al,…,am)和B=(b1,…,bn)均为顺序表,“比较”两个顺序表A和B的大小。设A’和B’分别为A和B中除去最大共同前缀后的子表(例如,A=(y,X,X,Z,X,Z),B=(y,x,x,z,y,x,x,2),则两者中最大的共同前缀为(y,x,x,2),在两表中除去最大共同前缀后的子表分别为A’=(X,Z)和B’=(y,x,x,2))。若A’=B’=空表,则 A=B:若A’=空表,而B’≠空表,或者两者均不为空表,且A’的首元小于B,的首元,则A<B;否则A>B。
提示:算法的基本思想为:若相等,则j+1,之后继续比较后继元素:否则即可得山比较结果。显然,j的初值应为0,循环的条件是j不超出其中任何一个表的范围。若在循环内不能得出比较结果,则循环结束时有3种可能出现的情况需要区分。
【函数1】
int compare(SqList A,SqList B)
{
//若A<B,则返回-1;若A=B,则返回o:若A>B,则返回1
j=0;
while(j<(1)&&j<B.1ength)
if( A.elem[j] < B.elem[j] ) return(-1);
else if( A.elem[j] > B.elem[j] ) return(i);
else (2)
ff (A.length == B.length) return (0);
else fi(A.length < B.length ) return(-1);
else return(1);
}//compare
//函数1的时间复杂度是 (3)
【函数2说明】
函数 exchange_L( SLink &L, int m )的功能是:用尽可能少的辅助空间将单链表中前 m个结点和后 n 个结点的互换。即将单链表(a1,a2,...,am,b1,b2,...,bn) 改变成 (b1,b2,...,bn,a1,a2,…,am)。
【函数2】
void exchange_L( SLink &L, int m )
{
if((4)&& L->next) // 链表不空且 m!=0
{
p = L->next; k = 1;
while( k< m && p ) // 查找am所在结点
{
p =(5); ++k;
}
if((6)&&p->next) //n!=0 时才需要修改指针
{
ha = L->next; // 以指针ha记a1 结点的位置
L->next = p->next; // 将b1结点链接在头结点之后
p->next = NULL; // 设am的后继为空
q:(7); // 令q 指向b1结点
while(q->next)q=(8); // 查的bn结点
q->next =(9); // 将a1 结点链接到bn 结点之后
}
}
}
//函数2的时间复杂度是(10)。
选项
答案
(1)A.length (2)j++ (3)O(Min(A.1ength,B.1ength)) (4)m (5)p->next (6) p (7)L->next (8)q->next (9) ha (10)O(ListLength(L))
解析
函数1中,算法要求对两个顺序表进行“比较”,是一种“引用型”操作,因此在算法中不应该破坏己知表。按题目中的规定,只有在两个表的长度相等,且每个对应元素都相同时才相等;否则,两个顺序表的大小主要取决于两表中除去最大公共前缀后的第一个元素。因此,比较两表的大小不应该先比较它们的长度,而应该设一个下标变量i同时控制两个表,即对两表中“位序相同”的元素进行比较。
上述算法中只有一个while循环,它的执行次数依赖于待比较的顺序表的表长,因此,算法的时间复杂度为O(Min(A.1enZ出,B.length))。
函数2中,对链表来说,“插入”和“删除”仅需修改指针即可完成,并且由于前m个元素之间和后n个元素之间的链接关系都不需要改变,则算法的实际操作为:
先从链表中删除(a1,a2,…,am),然后将(b1,b2,…,bn)链接到头结点之后,再将(a1,a2,…,am)链接到bn之后。
算法的时间复杂度为O(L1stlen2出(L))。
转载请注明原文地址:https://kaotiyun.com/show/EgDZ777K
本试题收录于:
软件设计师下午应用技术考试题库软考中级分类
0
软件设计师下午应用技术考试
软考中级
相关试题推荐
某教学管理数据库中,学生、课程关系模式和主键分别为:S(学号,姓名,性别,家庭住址,电话),关系S的主键为学号;C(课程号,课程名,学分),关系C的主键为课程号。假设一个学生可以选择多门课程,一门课程可以由多个学生选择。一旦学生选择某门课程必定有该课程的成
已知函数f()、g()的定义如下所示,调用函数f时传递给形参x的值是5。若g(a)采用引用调用(callbyreference)方式传递参数,则函数f的返回值为(12);若g(a)采用值调用(callbyvalue)的方式传递参数,则函数f
按照测试实施组织,可将测试划分为开发方测试、用户测试、第三方测试。下面关于开发方测试的描述正确的是______。①开发方测试通常也叫“验证测试”或“Alpha测试”②开发方测试又称“Beta测试”③开发方测试可以从软件产品编码结束之
关于软件测试与软件开发的认识,不正确的是______。A.软件生命周期各个阶段都可能产生错误B.软件测试是独立于软件开发的一个工作C.软件开发的需求分析和设计阶段就应开始测试工作D.测试越早进行,越有助于提高被测软件的质量
以下属于影响软件可靠性因素的是()。①软件运行剖面②软件规模③软件内部结构④软件的开发方法和开发环境⑤软件的可靠性投入
在面向对象方法中,______是一种概念、抽象或具有状态、行为和标识的事物。
下图中,类Product和ConcreteProduct的关系是(45),类ConcreteCreator和ConcreteProduct的关系是(46)。(46)
以下关于汇编语言的叙述中,错误的是______。A.汇编语言源程序中的指令语句将被翻译成机器代码B.汇编语言的指令语句必须具有操作码字段,可以没有操作数字段C.汇编程序以汇编语言源程序为输入,以机器语言表示的目标程序为输出D.汇编程序先将源程序中的
以下关于软件测试原则的叙述中,正确的是______。①测试开始得越早,越有利于发现缺陷②测试覆盖率和测试用例数量成正比③测试用例既需选用合理的输入数据,又需要选择不合理的输入数据④应制定测试计划并严格执行,排除随意性
CMM模型将软件过程的成熟度分为5个等级。在(21)使用定量分析来不断地改进和管理软件过程。
随机试题
某校发生一起高年级学生欺负低年级学生的事件,给低年级学生乱起外号,索要钱物,引起学校的高度重视并开始调查,此类学生的行为属于()。
需要调查某中学高一年级某班的历史成绩(单位:分),随机抽取该班20名同学,每位同学的期末历史成绩如下。(计算结果保留小数点后两位)90797380818583808576
男性,68岁。因气急,心悸,右上腹痛伴下肢浮肿2周入院,诊断为扩张型心肌病伴心力衰竭。此时应首先采取下列哪项措施
某大桥主跨为20×40m预应力混凝土简支T梁桥,合同总价为8700万元。大桥桥址处地质条件如下:原地面往下依次为粘土、砂砾石、泥岩,主墩基础为直径2.0m的钻空灌注桩,设计深度为40m,采用回转钻进施工法钻孔,导管法灌注水下混凝土。T梁施工采用预制吊装,预
Excel表格处理操作考试要求:(1)将标题字体设为“楷体”,24磅,加粗,置于表格正上方。(2)计算每个学生的总成绩和平均成绩,分别放入总成绩和平均成绩栏中,平均成绩保留一位小数。(3)为表格添加边框线,外框线为粗线,内框
对于“银行存款”账户,期末余额一期初余额+本期贷方发生额一本期借方发生额。()
某软件生产企业2014年实际支出的工资、薪金总额为60万元;职工福利费本期发生10万元;拨缴的工会经费1.20万元,其中取得工会经费收入专用收据1万元;职工教育经费列支了5万元,其中职工培训费用3万元。该企业期末所得税汇算清缴时纳税调整增加为()万
完善的市场体系必须具备的功能有()。
公文处理应遵循的原则不包括()。
Thoughsomepeoplehavesuggestedthatwomenshouldreturntohouseworkinordertoleavemorejobsformen,theideahasbeenr
最新回复
(
0
)