广义表

列表里面有列表,比如(1,(2,(3,4)),5)

用链表可以实现

结果如图

guangyibiao.h

#ifndef __GUANGYIBIAO__
#define __GUANGYIBIAO__ #include <stdio.h>
#include <string.h>
#include <memory.h>
#include <malloc.h>
#include <assert.h>
#include <stdbool.h>
#include <stdlib.h> #define AtomType int typedef enum{ATOM, LIST}ElemTag;
typedef struct GLNode{
ElemTag tag;
union{
AtomType atom;
struct GLNode* head;
};
struct GLNode* tail;
}GLNode; typedef GLNode* GenList; void init(GenList* gl);
void createGenList(GenList* gl, char* s);
void show(GenList gl); #endif

guangyibiao.c

#include "guangyibiao.h"

void init(GenList* gl){
*gl = NULL;
} //挑出逗号前的一个元素,元素可以是原子也可以是列表
bool server1(char* sub, char* hsub){ int n = strlen(sub);
int i = 0;
char ch = sub[0];
int k = 0;
//k的作用是,识别逗号是括号里的,还是括号外的,如果是括号外的逗号就跳出while了,括号内的逗号不跳出循环,继续往下找。
while(i < n && (ch != ',' || k != 0)){
if(ch == '('){
k++;
}
else if(ch == ')'){
k--;
}
i++;
ch = sub[i];
} //逗号在sub的范围内
if(i < n){
sub[i] = '\0';
strcpy(hsub, sub);
strcpy(sub, sub+i+1);
}
//括号不匹配
else if(k != 0) return false;
//sub本身就是表,比如为(1,2)时,i会等于n,所以把sub给hsub,sub就没有以后部分了
else{
strcpy(hsub, sub);
sub[0] = '\0';
} return true;
} //思路:递归创建节点,如果sub是列表,就递归调用自己
void createGenList(GenList* gl, char* s){ int n = strlen(s); //去掉s的外括号,比如s为(1,(2, 3)),处理后sub为1,(2, 3),并在sub的最后加上'\0'
char* sub = (char*)malloc(sizeof(char) * (n - 2));
char* hsub = (char*)malloc(sizeof(char) * (n - 2));
assert(NULL != sub && NULL != hsub);
strncpy(sub, s+1, n-2);
sub[n-2] = '\0'; GLNode* p = *gl;
while(strlen(sub) != 0){
if(NULL == p){
*gl = p = (GLNode*)malloc(sizeof(GLNode));
p->head = p->tail = NULL;
}else{
p = p->tail = (GLNode*)malloc(sizeof(GLNode));
p->head = p->tail = NULL;
}
assert(NULL != p); if(server1(sub, hsub)){
if(hsub[0] == '('){
p->tag = LIST;
createGenList(&(p->head), hsub);
}
else{
p->tag = ATOM;
p->atom = atoi(hsub);
}
}
}
}
//思路:递归
void show(GenList gl){
if(gl == NULL) return; if(gl->tag == ATOM){
printf("%d", gl->atom);
if(gl->tail != NULL){
printf(",");
}
//如果gl为ATOM的话,gl就不会有head,所以只需调用show(gl->tail)
show(gl->tail);
}
//如果gl为LIST的话,gl就会有head,也会有tail,所以调用show(gl->head),show(gl->tail)
else if(gl->tag == LIST){
printf("("); show(gl->head);
printf(")");
if(gl->tail != NULL){
printf(",");
}
show(gl->tail);
}
}

guangyibiaomai.c

#include "guangyibiao.h"

int main(){
GenList gl;
init(&gl); char* a = "(1,2,3)";
char* b = "(1,(2,3))";
char* c = "(1,(2),3)";
char* d = "((1,2),3)";
char* e = "((1,2,3))";
char* f = "((),1)";
char* g = "(1,(2,(3,4)),5)";
char* h = "((),1,(2,(3,(),4)),5)";
char* i = "(())"; createGenList(&gl, i);
if(gl != NULL){
printf("(");
show(gl);
printf(")\n");
} return 0;
}

c/c++ 广义表的更多相关文章

  1. 数据结构(C语言第2版)-----数组,广义表,树,图

    任何一个算法的设计取决于选定的数据结构,而算法的实现依赖于采用的存储结构. 之前线性表的数据元素都是非结构的原子类型,元素的值是不可再分的.下面学习的这两个线性表是很特殊的,其中数据元素本身也可能是一 ...

  2. 广义表 Head Tail

    head:取非空广义表的第一个元素 tail:取非空广义表除第一个元素外剩余元素构成的广义表 L=((x,y,z),a,(u,t,w)) head(L)为(x,y,z) head(head(L))为x ...

  3. 数据结构算法C语言实现(十九)--- 5.5&5.6&5.7广义表

    一.简述 传说Lisp的基本数据结构就是广义表,广义表也是具有典型递归属性的数据结构,此外,由于建表要处理字符串,用C语言处理起来也是一脸懵逼.....最后自己还想写一个将广义表还原成字符串的函数,一 ...

  4. javascript实现数据结构:广义表

    原文:javascript实现数据结构:广义表  广义表是线性表的推广.广泛用于人工智能的表处理语言Lisp,把广义表作为基本的数据结构. 广义表一般记作: LS = (a1, a2, ..., an ...

  5. 【C/C++】实现数据结构广义表

    1. 广义表的定义     每个元素可以为Atom,原子,也可以为线性表.      线性表的推广.线性表元素有唯一的前驱和后继,为线性表,而广义表是多层次的线性表      表头:第一个元素,可能是 ...

  6. 数据结构(C语言版)-第4章 串、数组和广义表

    补充:C语言中常用的串运算 调用标准库函数 #include<string.h> 串比较,strcmp(char s1,char s2) 串复制,strcpy(char to,char f ...

  7. 广义表操作 (ava实现)——广义表深度、广义表长度、打印广义表信息

    广义表是对线性表的扩展——线性表存储的所有的数据都是原子的(一个数或者不可分割的结构),且所有的数据类型相同.而广义表是允许线性表容纳自身结构的数据结构. 广义表定义: 广义表是由n个元素组成的序列: ...

  8. 数据结构:广义表的实现(Java)

    广义表的简单理解在这篇博文中:https://blog.csdn.net/lishanleilixin/article/details/87364496,在此不做赘述. Java实现广义表: pack ...

  9. 数据结构28:广义表及M元多项式

    广义表,又称为列表.记作: LS = (a1,a2,…,an) ;( LS 为广义表的名称, an 表示广义表中的数据). 广义表可以看作是线性表的推广.两者区别是:线性表中的数据元素只能表示单个数据 ...

随机推荐

  1. JSON初步认识

    一.背景 曾经有一段时间,XML是互联网传输结构化数据的标准.但是XML过于繁琐.冗长.JSON2001年就开始应用了,2006年,DC才把Json提交给IETF. 与XML相比,Json是在Java ...

  2. 【转载】SpringBoot系列——Swagger2

    微服务学习二:springboot与swagger2的集成:https://www.cnblogs.com/fengli9998/p/7522973.html 注:需要在启动类加 @EnableSwa ...

  3. VUE组件汇总

    内容 UI组件 开发框架 实用库 服务端 辅助工具 应用实例 Demo示例 UI组件 element ★13489 - 饿了么出品的Vue2的web UI工具套件 Vux ★8133 - 基于Vue和 ...

  4. C#序列化与反序列化。

    序列化介绍: 把对象用一种新的格式来表示. 系列化只序列化数据. 序列化不建议使用自动属性 为什么要序列化: 将一个复杂的对象转换流,方便存储与信息交换. class Program { static ...

  5. 一个小时学会Maven

    一.为什么要Maven 在开发中经常需要依赖第三方的包,包与包之间存在依赖关系,版本间还有兼容性问题,有时还里要将旧的包升级或降级,当项目复杂到一定程度时包管理变得非常重要. Maven是当前最受欢迎 ...

  6. 升级ssh到OpenSSH_7.5p1

    Redhat 6.5 x64升级SSH到OpenSSH_7.5p1 为了防止openssh安装失败导致不能远程登录,先部署telnet服务以防万一. rpm -qa telnet telnet-ser ...

  7. EF 传递的主键值的数量必须与实体上定义的主键值的数量匹配 原因

    主要是该数据表没有定义主键造成的

  8. Mysql索引的类型

    索引的类型 B-Tree索引 B-Tree 索引 通常意味着所有的值都是按顺序存储的,并且每一个叶子页到根的距离相同. B-Tree 索引 能够加快访问数据的速度,存储引擎不再需要进行全表扫描来获取需 ...

  9. 6. CountDownLatch 闭锁

    package com.gf.demo05; import java.util.concurrent.CountDownLatch; /** * CountDownLatch : 闭锁,在完成某些操作 ...

  10. sourcetree Authentication failed

    sourcetree 的 git 密码存在 mac 的 钥匙串里面, 需要在钥匙串里删除掉对应信息,再次打开就会让你重新输入密码, 问题就解决了。 参看: https://stackoverflow. ...