第九周项目四:广义表算法库及应用(1)

2024-01-09 02:48

本文主要是介绍第九周项目四:广义表算法库及应用(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*
Copyright (c)2015,烟台大学计算机与控制工程学院
All rights reserved.
文件名称:项目4-1.cbp
作    者:孙立立
完成日期:2015年12月4日
版 本 号:v1.0
问题描述:(1)建立广义表算法库,包括:
① 头文glist.h,定义数据类型,声明函数;
② 源文件glist.cpp,实现广义表的基本运算,主要算法包括:
int GLLength(GLNode *g);    //求广义表g的长度
int GLDepth(GLNode *g);     //求广义表g的深度
GLNode *CreateGL(char *&s); //返回由括号表示法表示s的广义表链式存储结构
void DispGL(GLNode *g);     //输出广义表g
③ 设计main函数,测试上面实现的算法
输入描述:无
程序输出:测试数据
*/


glist.h代码:

#ifndef GLIST_H_INCLUDED
#define GLIST_H_INCLUDED
#include <stdio.h>
#include <malloc.h>
typedef char ElemType;
typedef struct lnode
{
int tag;                    //节点类型标识
union
{
ElemType data;          //原子值
struct lnode *sublist;  //指向子表的指针
} val;
struct lnode *link;         //指向下一个元素
} GLNode;                       //广义表节点类型定义
int GLLength(GLNode *g);        //求广义表g的长度
int GLDepth(GLNode *g);     //求广义表g的深度
GLNode *CreateGL(char *&s);     //返回由括号表示法表示s的广义表链式存储结构
void DispGL(GLNode *g);                 //输出广义表g
#endif // GLIST_H_INCLUDED


glist.cpp代码:

#include "glist.h"
int GLLength(GLNode *g)     //求广义表g的长度
{
int n=0;
GLNode *g1;
g1=g->val.sublist;      //g指向广义表的第一个元素
while (g1!=NULL)
{
n++;                //累加元素个数
g1=g1->link;
}
return n;
}
int GLDepth(GLNode *g)      //求广义表g的深度
{
GLNode *g1;
int max=0,dep;
if (g->tag==0)          //为原子时返回0
return 0;
g1=g->val.sublist;      //g1指向第一个元素
if (g1==NULL)           //为空表时返回1
return 1;
while (g1!=NULL)        //遍历表中的每一个元素
{
if (g1->tag==1)     //元素为子表的情况
{
dep=GLDepth(g1);    //递归调用求出子表的深度
if (dep>max)    //max为同一层所求过的子表中深度的最大值
max=dep;
}
g1=g1->link;            //使g1指向下一个元素
}
return(max+1);          //返回表的深度
}
GLNode *CreateGL(char *&s)      //返回由括号表示法表示s的广义表链式存储结构
{
GLNode *g;
char ch=*s++;                       //取一个字符
if (ch!='\0')                      //串未结束判断
{
g=(GLNode *)malloc(sizeof(GLNode));//创建一个新节点
if (ch=='(')                    //当前字符为左括号时
{
g->tag=1;                   //新节点作为表头节点
g->val.sublist=CreateGL(s); //递归构造子表并链到表头节点
}
else if (ch==')')
g=NULL;                     //遇到')'字符,g置为空
else if (ch=='#')               //遇到'#'字符,表示为空表
g=NULL;
else                            //为原子字符
{
g->tag=0;                   //新节点作为原子节点
g->val.data=ch;
}
}
else                                 //串结束,g置为空
g=NULL;
ch=*s++;                            //取下一个字符
if (g!=NULL)                        //串未结束,继续构造兄弟节点
{
if (ch==',')                    //当前字符为','
g->link=CreateGL(s);        //递归构造兄弟节点
else                            //没有兄弟了,将兄弟指针置为NULL
g->link=NULL;
}
return g;                           //返回广义表g
}
void DispGL(GLNode *g)                  //输出广义表g
{
if (g!=NULL)                        //表不为空判断
{
//先处理g的元素
if (g->tag==0)                  //g的元素为原子时
printf("%c", g->val.data);  //输出原子值
else                            //g的元素为子表时
{
printf("(");                //输出'('
if (g->val.sublist==NULL)   //为空表时
printf("#");
else                        //为非空子表时
DispGL(g->val.sublist); //递归输出子表
printf(")");                //输出')'
}
if (g->link!=NULL)
{
printf(",");
DispGL(g->link);            //递归输出后续表的内容
}
}
}


main.cpp代码:

#include "glist.h"
int main()
{
GLNode *g;
char *s="(b,(b,a,(#),d),((a,b),c((#))))";
g = CreateGL(s);
DispGL(g);
printf("广义表长度:%d\n", GLLength(g));
printf("广义表深度:%d\n", GLDepth(g));
return 0;
}


运行结果:

这篇关于第九周项目四:广义表算法库及应用(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/585706

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

MyCat分库分表的项目实践

《MyCat分库分表的项目实践》分库分表解决大数据量和高并发性能瓶颈,MyCat作为中间件支持分片、读写分离与事务处理,本文就来介绍一下MyCat分库分表的实践,感兴趣的可以了解一下... 目录一、为什么要分库分表?二、分库分表的常见方案三、MyCat简介四、MyCat分库分表深度解析1. 架构原理2. 分

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳