广义表

列表里面有列表,比如(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. 打造SharePoint之在线开发神器SPOnlineDevelopTool(一)——概述

    做SharePoint开发有时候是一件比较痛苦的事情,毕竟庞大的框架总是笨重的~~ 往往如果采取传统的方式开发SharePoint的话,更改一个代码需要有以下操作: 1)更改代码 2)VS编译——&g ...

  2. python字符串(string)方法整理

    python中字符串对象提供了很多方法来操作字符串,功能相当丰富. print(dir(str)) [..........'capitalize', 'casefold', 'center', 'co ...

  3. 翻译:load data infile(已提交到MariaDB官方手册)

    本文为mariadb官方手册:LOAD DATA INFILE的译文. 原文:https://mariadb.com/kb/en/load-data-infile/ 我提交到MariaDB官方手册的译 ...

  4. iOS-CoreData详解与使用

    上面已经说完了SQLite和FMDB以及两者的区别,本篇将讲述iOS中另一个存储方式,CoreData的使用.通读下来大约10分钟,后续还会根据项目中问题,不断更新. 一.预备知识 在了解CoreDa ...

  5. C# string数组转int数组

    用法 //字符串数组(源数组) string[] sNums = new[] {"1", "2"}; //整型数组(目标数组) int[] iNums; //转 ...

  6. No application encryption key has been specified.

    环境:php7.1.10laravel5.5出现: 解决:在根目录下执行: php artisan key:generate OK问题解决

  7. Java类加载机制(加载、验证、准备、解析、初始化)

    如下图所示,Java的类加载机制主要分为三个部分,分别为加载.链接.初始化.其中链接又分为三个小部分--验证.准备.解析. 加载--在经过对Java代码进行编译后,JVM将Java类编译后的二进制文件 ...

  8. Integer Game(UVA11489)3的倍数

    K - Integer Game Time Limit:1000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Submit Status Pr ...

  9. Java8 使用stream实现各种list操作

    利用java8新特性,可以用简洁高效的代码来实现一些数据处理. 定义1个Apple对象: public class Apple { private Integer id; private String ...

  10. thinkphp——通过在线编辑器添加的内容在模板里正确显示(只显示内容,而不是html代码)

    thinkphp编辑器回显问题如下: 解决办法如下: 对于编辑器发布的内容,前台模板显示为html的解决办法是: 在模板输出字段加入html_entity_decode()函数 也就是:PHP输出时的 ...