// CTest.cpp : 定义控制台应用程序的入口点。
// #include "stdafx.h"
#include <iostream>
#include <string.h>
#include <stdio.h>
using namespace std; typedef char ElemType;
struct GLNode{
bool tag; //标志位
union{ //值域或子表的表头指针域
ElemType data;
GLNode *sublist;
};
GLNode *next;
};
//用来测试 (a,(b,(c)),(#),((d,e))),f,(g));
//求广义表的长度 广义表的长度就是求单链表的长度
int Lenth(GLNode *GL)
{
if(GL!=NULL){
return +Lenth(GL->next);
}else{
return ;
}
}
//求广义表的长度 广义表的长度就是求单链表的长度
int Depth(GLNode *GL)
{
int max=;
while(GL!=NULL){
if(GL->tag==true){
int dep = Depth(GL->sublist);
if(dep>max) max=dep;
}
GL=GL->next;
}
return max+;
}
//创建广义表
void Create(GLNode* &GL){
char ch;//读一个字符
cin>>ch;
//若输入#,则置GL为空
if(ch=='#') GL=NULL;
//若输入为左括号则建立由GL所指向的子表结点并递归构造字表
else if(ch='('){
GL = new GLNode;
GL->tag=true;
Create(GL->sublist);
}
else{
GL=new GLNode;
GL->tag=false;
GL->data=ch;
}
//此处读入的字符必为逗号,右括号或分号
cin>>ch;
//若GL为空,此时输入的字符必然为')',则什么都不用做
if(GL==NULL);
//若输入为逗号则递归构造后继表
else if(ch==',') Create(GL->next);
//若输入为右括号或分号则置GL的后继指针域为空
else if((ch==')')||(ch==';')) GL->next=NULL;
}
//打印输出广义表
void Print(GLNode *GL){
if(GL->tag==true){
cout<<'('; //对于表结点,则先输出左括号,作为开始符号
if(GL->sublist==NULL)
cout<<'#'; //若字表指针为空,则输出‘#’字符
else
Print(GL->sublist);//若为非空字表,则递归输出此表
cout<<')'; //当一个字表输出结束后,应输出右括号作为终止符
}
else cout<<GL->data; //对于单元素结点,输出该结点的值
if(GL->next!=NULL){ //输出GL结点的后继表
cout<<','; //先输出括号及分割符后
Print(GL->next); //再递归输出后继表
}
}
int _tmain(int argc, _TCHAR* argv[])
{
GLNode *g=NULL;
Create(g);
Print(g);
cout<<endl;
cout<<"广义表的长度:"<<Lenth(g->sublist)<<endl;
cout<<"广义表的深度:"<<Depth(g->sublist)<<endl;
system("pause");
return ;
}

数据结构 c++ 广义表的更多相关文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  9. 数据结构之---C语言实现广义表头尾链表存储表示

    //广义表的头尾链表存储表示 //杨鑫 #include <stdio.h> #include <malloc.h> #include <stdlib.h> #in ...

随机推荐

  1. day03-MyBatis的动态SQL语句查询

    场景一: 例如当我们想实现这样的查询的时候之前的操作貌似满足不了我们.  场景二: 还有些时候我们如果输入的信息越多满足要求的就越多,所查找出来的用户就越少 当我们之输入姓名的时候可能查找出10个人, ...

  2. Python 之并发编程之manager与进程池pool

    一.manager 常用的数据类型:dict list 能够实现进程之间的数据共享 进程之间如果同时修改一个数据,会导致数据冲突,因为并发的特征,导致数据更新不同步. def work(dic, lo ...

  3. ios中时间倒计时

    博客地址 https://github.com/sundayios/SQCountTimeDown.git

  4. ios中为视图添加圆角

    1.使用 layer设置指定圆角 或者设定一个或几个圆角 码修 关注 2017.04.20 19:03* 字数 107 阅读 656评论 0喜欢 0 由于项目中需要给按钮左下 和左上加圆角,我司可爱的 ...

  5. lua叠代器

    注意:叠待值遇到nil就退出 叠代器,是符合for遍历框架,需要满足条件 1-叠代函数,常量,控制变量 2-叠代函数可以接受二个参数,当然也可以忽略处理(利用闭包封装参数作为控制变量和状态变量) 无状 ...

  6. Java 8 有哪些新特性

    一.支持 lambda 表达式 例如:查询学生信息,并打印 List<Student> studentList = Student.findAllStudent(); for(Studen ...

  7. Windows驱动开发-手动创建IRP

    手动创建IRP有以下几个步骤: 1,先得到设备的指针,一种方法是用IoGetDeviceObjectPointer内核函数得到设备对象指针,另外一种方法是用zwCreateFile内核函数先得到设备句 ...

  8. STM32新MCU

    G0的出现完美的替换自家目前的F0系列而且有更好的性能和价格优势; STM32WL世界上首款LoRa Soc单片机嵌入了基于Semtech SX126x的经过特殊设计的无线电,该无线电提供两种功率输出 ...

  9. Linux命令:ss命令

    ss功能:用来显示套接字信息的,类似于netstat,可以显示更多的信息,用于替代netstat. ss常用选项 ss -t:tcp协议的连接 -u:udp协议的链接 -w:裸套接字相关 -x:uni ...

  10. 动态设置WX滚动条的高度(非常重要)

    wxml: <scroll-view class="scroll" scroll-y="true" style="height:{{client ...