c/c++ 广义表
广义表
列表里面有列表,比如(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++ 广义表的更多相关文章
- 数据结构(C语言第2版)-----数组,广义表,树,图
任何一个算法的设计取决于选定的数据结构,而算法的实现依赖于采用的存储结构. 之前线性表的数据元素都是非结构的原子类型,元素的值是不可再分的.下面学习的这两个线性表是很特殊的,其中数据元素本身也可能是一 ...
- 广义表 Head Tail
head:取非空广义表的第一个元素 tail:取非空广义表除第一个元素外剩余元素构成的广义表 L=((x,y,z),a,(u,t,w)) head(L)为(x,y,z) head(head(L))为x ...
- 数据结构算法C语言实现(十九)--- 5.5&5.6&5.7广义表
一.简述 传说Lisp的基本数据结构就是广义表,广义表也是具有典型递归属性的数据结构,此外,由于建表要处理字符串,用C语言处理起来也是一脸懵逼.....最后自己还想写一个将广义表还原成字符串的函数,一 ...
- javascript实现数据结构:广义表
原文:javascript实现数据结构:广义表 广义表是线性表的推广.广泛用于人工智能的表处理语言Lisp,把广义表作为基本的数据结构. 广义表一般记作: LS = (a1, a2, ..., an ...
- 【C/C++】实现数据结构广义表
1. 广义表的定义 每个元素可以为Atom,原子,也可以为线性表. 线性表的推广.线性表元素有唯一的前驱和后继,为线性表,而广义表是多层次的线性表 表头:第一个元素,可能是 ...
- 数据结构(C语言版)-第4章 串、数组和广义表
补充:C语言中常用的串运算 调用标准库函数 #include<string.h> 串比较,strcmp(char s1,char s2) 串复制,strcpy(char to,char f ...
- 广义表操作 (ava实现)——广义表深度、广义表长度、打印广义表信息
广义表是对线性表的扩展——线性表存储的所有的数据都是原子的(一个数或者不可分割的结构),且所有的数据类型相同.而广义表是允许线性表容纳自身结构的数据结构. 广义表定义: 广义表是由n个元素组成的序列: ...
- 数据结构:广义表的实现(Java)
广义表的简单理解在这篇博文中:https://blog.csdn.net/lishanleilixin/article/details/87364496,在此不做赘述. Java实现广义表: pack ...
- 数据结构28:广义表及M元多项式
广义表,又称为列表.记作: LS = (a1,a2,…,an) ;( LS 为广义表的名称, an 表示广义表中的数据). 广义表可以看作是线性表的推广.两者区别是:线性表中的数据元素只能表示单个数据 ...
随机推荐
- Linux常用命令之压缩和解压缩命令
目录 1.压缩解压缩格式 .gz 一.将文件压缩为 .gz 格式,只能压缩文件:gzip 二.将 .gz 文件解压:gunzip 2.压缩解压缩格式 .tar.gz 一.将文件或目录压缩为 .tar. ...
- Java 容器源码分析之 TreeMap
TreeMap 是一种基于红黑树实现的 Key-Value 结构.在使用集合视图在 HashMap 中迭代时,是不能保证迭代顺序的: LinkedHashMap 使用了双向链表,保证按照插入顺序或者访 ...
- Socket网络编程基本介绍
一,socket的起源 socket一词的起源 在组网领域的首次使用是在1970年2月12日发布的文献IETF RFC33中发现的, 撰写者为Stephen Carr.Steve Crocker和Vi ...
- Linux下获取java堆栈文件并进行分析
当服务器内存飙升或者cpu负载飙升的时候,可以使用如下步骤排查问题: 1.终端输入top命令,键盘大写的情况下按P(cpu负载率从高到低排序)或者M(内存使用率从高到低排序),可以查看导致cpu或者内 ...
- gcc:call to '__open_missing_mode' declared with attribute error
因为使用 open 函数的时候,如果在第二个参数中使用了 O_CREAT,就必须添加第三个参数:创建文件时赋予的初始权限.这个取决于 gcc 的版本,有的版本不会报这个错误. 解决办法: 找到源码中报 ...
- HTML+CSS基础(2)-HTML标签的简单介绍和网页注释
标签的语法和基本规则 1.语法"<xxx></xxx>",英文的"<>"将标签括起来,如例1. <!--例1--> ...
- 【转载】ASP.NET生成图片的缩略图
图片处理是C#程序开发中时常会涉及到的一个业务,除了图像的上传.保存以及下载等功能外,根据上传的图片生成一个缩略图也是常见业务,在C#语言中,可以通过Image类提供的相关方法对图片进行操作,如指定宽 ...
- C# 操作注册表WindowsRegistry
using System; using System.Collections.Generic; using System.Linq; using System.Text; using Microsof ...
- Centos7.6 在LNMP上部署禅道
一.下载禅道,并传到你的服务器上面的/opt文件下. http://dl.cnezsoft.com/zentao/7.3/ZenTaoPMS.7.3.stable.zbox_64.tar.gz 二.使 ...
- 近20个绚丽实用的jQuery/CSS3侧边栏菜单(转载)
http://developer.51cto.com/art/201510/493530.htm 近20个绚丽实用的jQuery/CSS3侧边栏菜单 jQuery作为一款主流的JavaScript前端 ...