首页
消除递归不一定需要使用栈,此说法()。
精华吧
→
答案
→
慕课
→
未分类
消除递归不一定需要使用栈,此说法()。
A.正确
B.错误
正确答案:正确
Tag:
数据结构
递归
说法
时间:2022-01-04 13:52:43
上一篇:
在下面的程序段中,对x的赋值语句的频度为()。for(i=1;in;i++)for(j=1;jn;j++)x=x+1;
下一篇:
两个栈共享一片连续内存空间时,为提高内存利用率,减少溢出,应把两个栈的栈底分别设在这片内存空间的两端。()
相关答案
1.
设某顺序表中第一个元素的地址是Base,下标从1开始,每个结点占m个单元,则第i个结点的地址为()。
2.
当利用大小为n的数组顺序存储一个栈时,假定用top=n表示栈空,则每次向这个栈插入一个元素时,首先应执行()语句修改top指针。
3.
循环队列存储在数组A[0..m-1]中,则入队时rear应该变化为()。
4.
对于一个具有n个结点的单链表,在已知的结点*p后插入一个新结点的时间复杂度和在给定值为x的结点后插入一个新结点的时间复杂度分别为()。
5.
在双向链表(结点包括:data,prior,next)中,删除指针p所指向的结点时须修改指针()。
6.
一个栈的输入序列为1,2,3,…,n,若输出序列的第一个元素是i,则输出第j(1=j=i)个元素是()。
7.
一个栈的输入序列为12345,则下列序列中不可能是栈的输出序列的是()。
8.
输入序列为ABC,想要得到CBA的输出结果,可以经过的栈操作为()。
9.
一个递归算法必须包括()。
10.
若一个栈以数组V[0..n-1]存储,初始栈顶指针top为n,则下面关于元素x进栈的正确操作是()。
热门答案
1.
以下程序的输出结果为()。intf(intx){return(x0)?x*f(x-1):2;}voidmain(){inti;i=f(f(1));printf(%d,i);}
2.
下列说法正确的是()。(1)只有使用了局部变量的递归函数在转换成非递归函数时才必须使用栈。(2)队列是插入与删除操作在表的两端进行的线性表,具有先进后出的特点。(3)队列是一端进行删除另外一端进行插入的线性表。(4)循环队列也存在空间溢出问题。
3.
用带头结点的表长大于1的单链表表示队列时,其队头指针指向队头结点,其队尾指针指向队尾结点,则在进行删除操作时()。
4.
假设以数组A[m]存放循环队列的元素,其头、尾指针分别为front和rear,front指示实际的队头元素,rear指向实际队尾元素的下一个元素位置,则当前队列中的元素个数为()。
5.
最大容量为n的循环队列,队尾指针为rear,队头指针为front,则队空的条件是()。
6.
若用一个大小为6的数组来实现循环队列,且当前rear和front的值分别为3和1,当从队列中删除一个元素再加入两个元素后,rear和front的值为()。
7.
函数递归调用时,处理参数及返回地址需要用一种()的数据结构。
8.
表达式a*(b+c)-d的后缀表达式是()。
9.
设计一个判别表达式中括号是否匹配出现的算法,采用()的数据结构最佳。
10.
设栈S和队列Q的初始状态为空,元素e1,e2,e3,e4,e5和e6依次通过栈S,一个元素出栈后随即进入队列Q,若6个元素出队的序列是e2,e4,e3,e6,e5,e1,则栈S的容量至少应该是()。