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

2024-03-15 11:59

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

/*
*Copyright (c) 2015,烟台大学计算机学院
*All right reserved.
*文件名称:test.cpp
*作者:王雪洁
*完成日期:2015年11月2日
*版本号:v1.0
*问题描述:建立广义表算法库,包括: 
① 头文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
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 <stdio.h>
#include <malloc.h>
#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函数

#include <stdio.h>
#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;
}


运行结果:

知识点总结:

建立广义表可以帮我们解决稀疏矩阵三元组表示的基本运算。

学习心得:

新的算法库可以让运算变的更容易一些

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



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

相关文章

Redis中Stream详解及应用小结

《Redis中Stream详解及应用小结》RedisStreams是Redis5.0引入的新功能,提供了一种类似于传统消息队列的机制,但具有更高的灵活性和可扩展性,本文给大家介绍Redis中Strea... 目录1. Redis Stream 概述2. Redis Stream 的基本操作2.1. XADD

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅