信管网每日一练
软件设计师 - 每日一练 导航

软件设计师案例分析每日一练试题(2022/7/1)

2022年07月02日来源:信管网 作者:cnitpm

软件设计师案例分析当天每日一练试题地址:www.cnitpm.com/exam/ExamDayAL.aspx?t1=4

往期软件设计师每日一练试题汇总:www.cnitpm.com/class/27/e4_1.html

软件设计师案例分析每日一练试题(2022/7/1)在线测试:www.cnitpm.com/exam/ExamDayAL.aspx?t1=4&day=2022/7/1

点击查看:更多软件设计师习题与指导

软件设计师案例分析每日一练试题内容(2022/7/1)

试题五
阅读下列说明和C代码,将应填入    处的字句写在对应栏内。
【说明】
栈(Stack)结构是计算机语言实现中的一种重要数据结构。对于任意栈,进行插入和删除操作的一端称为栈顶(Stock Top),而另一端称为栈底(Stock Bottom)。栈的基本操作包括:创建栈(NewStack)、判断栈是否为空(IsEmpty)、判断栈是否已满(IsFull)、获取栈顶数据(Top)、压栈/入栈(Push)、弹栈/出栈(Pop)。
当设计栈的存储结构时,可以采取多种方式。其中,采用链式存储结构实现的栈中各数据项不必连续存储(如下图所示)。

以下C代码采用链式存储结构实现一个整数栈操作。
【C代码】
typedef struct List {
int data;                  //栈数据
struct List* next;         //上次入栈的数据地址
}List;
typedef struct Stack{
List* pTop;                //当前栈顶指针
}Stack;
Stack* NewStack()  {return (Stack*) calloc(1/sizeof(Stack));}
int IsEmpty(Stack* S){//判断栈S是否为空栈
if(  (1)  )return 1;
return 0;
}
int Top(Stack* s){//获取栈顶数据。若栈为空,则返回机器可表示的最小整数
if(IsEmpty(S))return INT_ MIN;
return  (2)  ;
}
void Push(Stack* S,int theData) {//将数据theData压栈
List* newNode;
newNode=(List*)calloc(1/sizeof (List));
newNode->data=theData;
newNode->next=S->pTop;
S->pTop=  (3)  ;
}
void Pop(Stack* S)  {//弹栈
List* lastTop;
if(IsEmpty(S)  )  return;
lastTop=S->pTop;
S->pTop=  (4)  ;
free(lastTop);
}
#define MD(a)  a<<2
int main(){
int i;
Stack* myStack;
myStack= NewStack();
Push(myStack,MD(1));
Push(myStack,MD(2));
Pop(myStack);
Push(myStack,MD(3)+1);
while( !IsEmpty(myStack)  ){
printf("%d",Top(myStack));
Pop(myStack);
}
return 0;
}
以上程序运行时的输出结果为:  (5)



信管网试题答案与解析:www.cnitpm.com/st/245685491.html

信管网考友试题答案分享:

信管网试题答案与解析:www.cnitpm.com/st/245685491.html

温馨提示:因考试政策、内容不断变化与调整,信管网提供的以上信息仅供参考,如有异议,请考生以权威部门公布的内容为准!

分享至:

信管网 - 信息系统项目管理专业网站

下载APP-在线学习

培训课程

0元畅享

考试题库

免费资料

客服咨询