数据结构c语言版3.19答案,[转载]数据结构(C语言版)例题(第三章:栈和队列)...-程序员宅基地

技术标签: 数据结构c语言版3.19答案  

◆3.15③

假设以顺序存储结构实现一个双向栈,即在一维数组的存

储空间中存在着两个栈,它们的栈底分别设在数组的的两个端点。

试编写实现这个双向栈tws的三个操作:初始化inistack(tws)、入栈

push(tws,i,x)和出栈pop(tws,i,x)的算法,

其中i为0或1,用以分

别指示设在数组两端的两个栈,并讨论按过程(正/误状态变量可设

为变参)或函数设计这些操作算法各有什么优缺点。

实现下列3个函数:

Status InitStack(TwoWayStack &tws, int size);

Status Push(TwoWayStack &tws, int i, SElemType

x);

Status Pop(TwoWayStack &tws, int i, SElemType

&x);

双向栈类型定义如下:

typedef struct {

SElemType

*elem;

int top[2];

int size; //

分配给elem的总容量

}TwoWayStack; // 双端栈

Status InitStack(TwoWayStack

&tws, int size)

{

tws.elem=(SElemType*)malloc(sizeof(SElemType)*size); tws.size=size; tws.top[0]=0; //hao tws.top[1]=size-1; return OK;

}

Status Push(TwoWayStack

&tws, int i, SElemType x)

{int w=tws.top[0]; if(w==tws.top[1]) return

ERROR; else if(i==0) { tws.elem[tws.top[0]]=x; tws.top[0]=tws.top[0]+1; } else if(i==1) { tws.elem[tws.top[1]]=x; tws.top[1]=tws.top[1]-1; } return OK;

}

Status Pop(TwoWayStack

&tws, int i, SElemType &x)

{ if(tws.top[1]==tws.size-1&&i==1)

return ERROR; else

if(tws.top[0]==0&&i==0) return

ERROR; else if(i==0) { tws.top[0]-=1; x=tws.elem[tws.top[0]]; } else if(i==1) { tws.top[1]+=1; x=tws.elem[tws.top[1]]; } return x;

}

◆3.16② 假设如题3.1所述火车调度站的入口处有n节

硬席或软席车厢(分别以H和S表示)等待调度,试编

写算法,输出对这n节车厢进行调度的操作(即入栈

或出栈操作)序列,以使所有的软席车厢都被调整到

硬席车厢之前。

实现下列函数:

void SwitchYard(SqList train, char

*s); 顺序表类型定义如下:

typedef struct {

ElemType

*elem;

int length;

int listsize;

} SqList; // 顺序表

void SwitchYard(SqList train, char

*s)

{ int i,j=0,L; char *p; L=train.length;p=s;

for(i=0;i<=L-1;i++) { if(train.elem[i]=='H') {*(p++)='U';j++;} else { *p='U'; p++; *p='O'; p++; } } for(;j>0;j--)

{ *p='O';p++; }

}

◆3.19④

假设一个算术表达式中可以包含三种括号:圆括号"("

")",方括号"["和"]"和花括号"{"和"}",且这三种括号可按任意的

次序嵌套使用(如:…[…{…}…[…]…]…[…]…(…)…)。编写判别给定表达

式中所含括号是否正确配对出现的算法(已知表达式已存入数据元素

为字符的顺序表中)。

实现下列函数:

Status MatchCheck(SqList

exp);

顺序表类型定义如下:

typedef struct {

ElemType

*elem;

int length;

int listsize;

} SqList; // 顺序表

Stack是一个已实现的栈。

可使用的相关类型和函数:

typedef char SElemType; // 栈Stack的元素类型

Status InitStack(Stack &s);

Status Push(Stack &s, SElemType e);

Status Pop(Stack &s, SElemType

&e);

Status StackEmpty(Stack s);

Status GetTop(Stack s, SElemType

&e);

Status MatchCheck(SqList exp)

{ Stack s;

char *p;

SElemType c;

InitStack(s);

for(p=exp.elem;*p;p++)

{

if(*p=='('||*p=='['||*p=='{') Push(s,*p);

else

if(*p==')'||*p==']'||*p=='}')

{

if(StackEmpty(s)) return FALSE;

Pop(s,c);

if(*p==')'&&c!='(') return

FALSE;

if(*p==']'&&c!='[') return

FALSE;

if(*p=='}'&&c!='{') return

FALSE;

}

}

if(!StackEmpty(s)) return FALSE;

return TRUE;

}

◆3.20③

假设以二维数组g(1..m,1..n)表示一个图像

区域,g[i,j]表示该区域中点(i,j)所具颜色,其值

为从0到k的整数。编写算法置换点(i0,j0)所在区域

的颜色。约定和(i0,j0)同色的上、下、左、右的邻

接点为同色区域的点。

实现下列函数:

void ChangeColor(GTYPE g, int m, int n, char c,

int i0, int j0);

表示图像区域的类型定义如下:

typedef char GTYPE[m+1][n+1];

Stack是一个已实现的栈。

可使用的相关类型和函数:

typedef int SElemType; // 栈Stack的元素类型

Status StackInit(Stack &s, int initsize);

Status Push(Stack &s, SElemType e);

Status Pop(Stack &s, SElemType

&e);

Status StackEmpty(Stack s);

Status GetTop(Stack s, SElemType

&e);

void ChangeColor(GTYPE g, int m, int

n,char c, int i0, int j0)

{ int x,y,old;

Stack

s; old=g[i0][j0];

StackInit(s,m*n*2);

Push(s,i0);

Push(s,j0);

while(!StackEmpty(s))

{

Pop(s,y);

Pop(s,x);

if(x>1)

if(g[x-1][y]==old)

{

g[x-1][y]=c;

Push(s,x-1);

Push(s,y);

}

if(y>1)

if(g[x][y-1]==old)

{

g[x][y-1]=c;

Push(s,x);

Push(s,y-1);

}

if(x

if(g[x+1][y]==old)

{

g[x+1][y]=c;

Push(s,x+1);

Push(s,y);

}

if(y

if(g[x][y+1]==old)

{

g[x][y+1]=c;

Push(s,x);

Push(s,y+1);

}

}

}

◆3.21③ 假设表达式由单字母变量和双目四则运

算算符构成。试写一个算法,将一个通常书写形式

且书写正确的表达式转换为逆波兰式。

实现下列函数:

char *RPexpression_r(char *e);

Stack是一个已实现的栈。

可使用的相关类型和函数:

typedef char SElemType; // 栈Stack的元素类型

Status InitStack(Stack &s);

Status Push(Stack &s, SElemType e);

Status Pop(Stack &s, SElemType

&e);

Status StackEmpty(Stack s);

SElemType Top(Stack s);

char *RPexpression_r(char *e)

{ static char b[20]; char *a=b; char w3='k'; char w; char w1,w2; Stack S; InitStack(S); while(*e!=' ') { switch(*e) { case '+': if(!StackEmpty(S)) { Pop(S,w2); Push(S,w2); if(w2=='*'||w2=='/'||w2=='+'||w2=='-') { Pop(S,w); *a=w; a++; } w2=Top(S); if(w2=='+'||w2=='-') { Pop(S,w); *a=w; a++; } Push(S,*e); } //if(!StackEmpty(S)) else Push(S,*e); e++; break; case '-': if(!StackEmpty(S)) { Pop(S,w2); Push(S,w2); if(w2=='*'||w2=='/'||w2=='+'||w2=='-') { Pop(S,w); *a=w; a++; } w2=Top(S); if(w2=='+'||w2=='-') { Pop(S,w); *a=w; a++; } Push(S,*e); } //if(!StackEmpty(S)) else Push(S,*e); e++; break; case '*': if(!StackEmpty(S)) { Pop(S,w2); Push(S,w2); if(w2=='*'||w2=='/') { Pop(S,w); *a=w; a++; } Push(S,*e); } //if(!StackEmpty(S)) else Push(S,*e); e++; break; case '/': if(!StackEmpty(S)) { Pop(S,w2); Push(S,w2); if(w2=='*'||w2=='/') { Pop(S,w); *a=w; a++; } Push(S,*e); } //if(!StackEmpty(S)) else Push(S,*e); e++; break; case '(': Push(S,*e); e++; break; case ')': while(w3!='('&&!StackEmpty(S)) { Pop(S,w3); if(w3!='(') { *a=w3; a++; } } //while w3='k'; e++; break; default: *a=*e; a++; e++; break; } //switch(*e) } //while(*e!=' ') while(!StackEmpty(S)) { Pop(S,w); *a=w; a++; } *a=' '; return b;

}

◆3.24③

试编写如下定义的递归函数的递归算法:

g(m,n) =

0 当m=0,n>=0

g(m,n) = g(m-1,2n)+n 当m>0,n>=0

并根据算法画出求g(5,2)时栈的变化过程。

实现下列函数:

int G(int m, int n);

int G(int m, int n)

{int s;

if(m<0||n<0)return -1;

if(m==0&&n>=0)

s=0;

else

if(m>0&&n>=0)

s=n+G(m-1,2*n);

return s;

}

◆3.25④

试写出求递归函数F(n)的递归算法,

并消除递归:

F(n) =

n+1 当n=0

F(n) =

nF(n/2) 当n>0

实现下列函数:

int F(int n);

int F(int n)

{int s;

if(n<0) return -1;

if(n==0) s=n+1;

else

{

s=n*F(n/2);

}

return s;

}

◆3.28②

假设以带头结点的循环链表表示队列,并且

只设一个指针指向队尾元素结点(注意不设头指针),

试编写相应的队列初始化、入队列和出队列的算法。

实现下列函数:

Status InitCLQueue(CLQueue &rear);

Status EnCLQueue(CLQueue &rear, ElemType x);

Status DeCLQueue(CLQueue &rear, ElemType

&x);

带头结点循环链队列CLQueue的类型为以下LinkList类型:

typedef struct LNode{

ElemType

data;

struct LNode

*next;

} LNode, *LinkList;

typedef LinkList CLQueue;

Status InitCLQueue(CLQueue

&rear)

{ rear=(CLQueue)malloc(sizeof(LNode)); rear->next=rear; return (OK);

}

Status EnCLQueue(CLQueue

&rear, ElemType x)

{LinkList p; p=(CLQueue)malloc(sizeof(LNode)); p->data=x; p->next=rear->next; rear->next=p; rear=p; return OK;

}

Status DeCLQueue(CLQueue

&rear, ElemType &x)

{LinkList q; if(rear==rear->next) return ERROR

; q=rear->next->next; x=q->data; rear->next->next=q->next; free(q); return OK;

}

◆3.29③

如果希望循环队列中的元素都能得到利用,

则需设置一个标志域tag,并以tag的值为0或1来区

分,尾指针和头指针值相同时的队列状态是"空"还

是"满"。试编写与此结构相应的入队列和出队列的

算法,并从时间和空间角度讨论设标志和不设标志

这两种方法的使用范围(比如,当循环队列容量较

小而队列中每个元素占的空间较多时,那一种方法

较好?)。

实现下列函数:

Status EnCQueue(CTagQueue &Q, QElemType x);

Status DeCQueue(CTagQueue &Q, QElemType

&x);

本题的循环队列CTagQueue的类型定义如下:

typedef char QElemType;

typedef struct {

QElemType

elem[MAXQSIZE];

int

tag;

int

front;

int

rear;

} CTagQueue;

Status EnCQueue(CTagQueue

&Q, QElemType x)

{if(Q.rear==Q.front&&Q.tag==1)

return ERROR; else { Q.elem[Q.rear]=x; Q.rear++; if(Q.rear==Q.front)

Q.tag=1; return OK; }

}

Status DeCQueue(CTagQueue

&Q, QElemType &x)

{ if(Q.rear==Q.front&&Q.tag==0)

return ERROR; else { x=Q.elem[Q.front]; Q.front++; if(Q.rear==Q.front)

Q.tag=0; return OK; }

}

◆3.30② 假设将循环队列定义为:以域变量rear

和length分别指示循环队列中队尾元素的位置和内

含元素的个数。试给出此循环队列的队满条件,并

写出相应的入队列和出队列的算法(在出队列的算

法中要返回队头元素)。

实现下列函数:

Status EnCQueue(CLenQueue &Q, QElemType x);

Status DeCQueue(CLenQueue &Q, QElemType

&x);

本题的循环队列CLenQueue的类型定义如下:

typedef char QElemType;

typedef struct {

QElemType

elem[MAXQSIZE];

int

length;

int

rear;

} CLenQueue;

Status EnCQueue(CLenQueue

&Q, QElemType x)

{if(Q.length==MAXQSIZE) return ERROR; else { Q.rear=Q.rear+1; Q.elem[Q.rear]=x; Q.length++; return OK; }

}

Status DeCQueue(CLenQueue

&Q, QElemType &x)

{ if(Q.length==0) return ERROR; else { int front; front=front+1; Q.length--; return OK; }

}

◆3.31③ 假设称正读和反读都相同的字符序列为

"回文",例如,'abba'和'abcba'是回文,'abcde'

和'ababab'则不是回文。试写一个算法判别读入的

一个以'@'为结束符的字符序列是否是"回文"。

实现下列函数:

Status Palindrome(char *word);

可使用栈Stack和队列Queue及其下列操作:

Status InitStack(Stack

&S); Status Push(Stack &S, ElemType

x); Status Pop(Stack &S, ElemType

&x); Status StackEmpty(Stack

S);

Status InitQueue(Queue

&Q);

Status EnQueue(Queue &Q, ElemType x);

Status DeQueue(Queue &Q, ElemType

&x);

Status QueueEmpty(Queue Q);

Status Palindrome(char *word)

{ char a,b; Stack S; Queue Q; InitStack(S); InitQueue(Q); while(*word!='@') { Push(S,*word); EnQueue(Q,*word); word++; } while(!StackEmpty(S))

{ Pop(S,a); DeQueue(Q,b); if(a!=b) return ERROR; } return OK;

}

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_31300407/article/details/117044557

智能推荐

分布式光纤传感器的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告_预计2026年中国分布式传感器市场规模有多大-程序员宅基地

文章浏览阅读3.2k次。本文研究全球与中国市场分布式光纤传感器的发展现状及未来发展趋势,分别从生产和消费的角度分析分布式光纤传感器的主要生产地区、主要消费地区以及主要的生产商。重点分析全球与中国市场的主要厂商产品特点、产品规格、不同规格产品的价格、产量、产值及全球和中国市场主要生产商的市场份额。主要生产商包括:FISO TechnologiesBrugg KabelSensor HighwayOmnisensAFL GlobalQinetiQ GroupLockheed MartinOSENSA Innovati_预计2026年中国分布式传感器市场规模有多大

07_08 常用组合逻辑电路结构——为IC设计的延时估计铺垫_基4布斯算法代码-程序员宅基地

文章浏览阅读1.1k次,点赞2次,收藏12次。常用组合逻辑电路结构——为IC设计的延时估计铺垫学习目的:估计模块间的delay,确保写的代码的timing 综合能给到多少HZ,以满足需求!_基4布斯算法代码

OpenAI Manager助手(基于SpringBoot和Vue)_chatgpt网页版-程序员宅基地

文章浏览阅读3.3k次,点赞3次,收藏5次。OpenAI Manager助手(基于SpringBoot和Vue)_chatgpt网页版

关于美国计算机奥赛USACO,你想知道的都在这_usaco可以多次提交吗-程序员宅基地

文章浏览阅读2.2k次。USACO自1992年举办,到目前为止已经举办了27届,目的是为了帮助美国信息学国家队选拔IOI的队员,目前逐渐发展为全球热门的线上赛事,成为美国大学申请条件下,含金量相当高的官方竞赛。USACO的比赛成绩可以助力计算机专业留学,越来越多的学生进入了康奈尔,麻省理工,普林斯顿,哈佛和耶鲁等大学,这些同学的共同点是他们都参加了美国计算机科学竞赛(USACO),并且取得过非常好的成绩。适合参赛人群USACO适合国内在读学生有意向申请美国大学的或者想锻炼自己编程能力的同学,高三学生也可以参加12月的第_usaco可以多次提交吗

MySQL存储过程和自定义函数_mysql自定义函数和存储过程-程序员宅基地

文章浏览阅读394次。1.1 存储程序1.2 创建存储过程1.3 创建自定义函数1.3.1 示例1.4 自定义函数和存储过程的区别1.5 变量的使用1.6 定义条件和处理程序1.6.1 定义条件1.6.1.1 示例1.6.2 定义处理程序1.6.2.1 示例1.7 光标的使用1.7.1 声明光标1.7.2 打开光标1.7.3 使用光标1.7.4 关闭光标1.8 流程控制的使用1.8.1 IF语句1.8.2 CASE语句1.8.3 LOOP语句1.8.4 LEAVE语句1.8.5 ITERATE语句1.8.6 REPEAT语句。_mysql自定义函数和存储过程

半导体基础知识与PN结_本征半导体电流为0-程序员宅基地

文章浏览阅读188次。半导体二极管——集成电路最小组成单元。_本征半导体电流为0

随便推点

【Unity3d Shader】水面和岩浆效果_unity 岩浆shader-程序员宅基地

文章浏览阅读2.8k次,点赞3次,收藏18次。游戏水面特效实现方式太多。咱们这边介绍的是一最简单的UV动画(无顶点位移),整个mesh由4个顶点构成。实现了水面效果(左图),不动代码稍微修改下参数和贴图可以实现岩浆效果(右图)。有要思路是1,uv按时间去做正弦波移动2,在1的基础上加个凹凸图混合uv3,在1、2的基础上加个水流方向4,加上对雾效的支持,如没必要请自行删除雾效代码(把包含fog的几行代码删除)S..._unity 岩浆shader

广义线性模型——Logistic回归模型(1)_广义线性回归模型-程序员宅基地

文章浏览阅读5k次。广义线性模型是线性模型的扩展,它通过连接函数建立响应变量的数学期望值与线性组合的预测变量之间的关系。广义线性模型拟合的形式为:其中g(μY)是条件均值的函数(称为连接函数)。另外,你可放松Y为正态分布的假设,改为Y 服从指数分布族中的一种分布即可。设定好连接函数和概率分布后,便可以通过最大似然估计的多次迭代推导出各参数值。在大部分情况下,线性模型就可以通过一系列连续型或类别型预测变量来预测正态分布的响应变量的工作。但是,有时候我们要进行非正态因变量的分析,例如:(1)类别型.._广义线性回归模型

HTML+CSS大作业 环境网页设计与实现(垃圾分类) web前端开发技术 web课程设计 网页规划与设计_垃圾分类网页设计目标怎么写-程序员宅基地

文章浏览阅读69次。环境保护、 保护地球、 校园环保、垃圾分类、绿色家园、等网站的设计与制作。 总结了一些学生网页制作的经验:一般的网页需要融入以下知识点:div+css布局、浮动、定位、高级css、表格、表单及验证、js轮播图、音频 视频 Flash的应用、ul li、下拉导航栏、鼠标划过效果等知识点,网页的风格主题也很全面:如爱好、风景、校园、美食、动漫、游戏、咖啡、音乐、家乡、电影、名人、商城以及个人主页等主题,学生、新手可参考下方页面的布局和设计和HTML源码(有用点赞△) 一套A+的网_垃圾分类网页设计目标怎么写

C# .Net 发布后,把dll全部放在一个文件夹中,让软件目录更整洁_.net dll 全局目录-程序员宅基地

文章浏览阅读614次,点赞7次,收藏11次。之前找到一个修改 exe 中 DLL地址 的方法, 不太好使,虽然能正确启动, 但无法改变 exe 的工作目录,这就影响了.Net 中很多获取 exe 执行目录来拼接的地址 ( 相对路径 ),比如 wwwroot 和 代码中相对目录还有一些复制到目录的普通文件 等等,它们的地址都会指向原来 exe 的目录, 而不是自定义的 “lib” 目录,根本原因就是没有修改 exe 的工作目录这次来搞一个启动程序,把 .net 的所有东西都放在一个文件夹,在文件夹同级的目录制作一个 exe._.net dll 全局目录

BRIEF特征点描述算法_breif description calculation 特征点-程序员宅基地

文章浏览阅读1.5k次。本文为转载,原博客地址:http://blog.csdn.net/hujingshuang/article/details/46910259简介 BRIEF是2010年的一篇名为《BRIEF:Binary Robust Independent Elementary Features》的文章中提出,BRIEF是对已检测到的特征点进行描述,它是一种二进制编码的描述子,摈弃了利用区域灰度..._breif description calculation 特征点

房屋租赁管理系统的设计和实现,SpringBoot计算机毕业设计论文_基于spring boot的房屋租赁系统论文-程序员宅基地

文章浏览阅读4.1k次,点赞21次,收藏79次。本文是《基于SpringBoot的房屋租赁管理系统》的配套原创说明文档,可以给应届毕业生提供格式撰写参考,也可以给开发类似系统的朋友们提供功能业务设计思路。_基于spring boot的房屋租赁系统论文