求通过data域比较两个广义表是否相等的代码模板,Java的

 我来答
打伞鱼Aw
2016-04-14 · TA获得超过7266个赞
知道大有可为答主
回答量:7524
采纳率:90%
帮助的人:1602万
展开全部
试编写判别两个广义表是否相等的递归算法。
广义表类型GList的定义:

[cpp] view plain copy
typedef enum {ATOM,LIST} ElemTag;
typedef struct GLNode{
ElemTag tag;
union {
char atom;
struct {
GLNode *hp, *tp;
} ptr;
}un;
} *GList;
实现的函数如下:

[cpp] view plain copy
Status Equal(GList A, GList B)
/* 判断广义表A和B是否相等,是则返回TRUE,否则返回FALSE */
{
if(A -> tag == ATOM && B -> tag == ATOM){
//当都为原子节点ATOM时
if(A -> un.atom == B -> un.atom)
return TRUE;
else
return FALSE;
}else if(A -> tag == LIST && B -> tag == LIST){
//当都为广义表节点LIST时
if(Equal(A -> un.ptr.hp,B -> un.ptr.hp) && Equal(A -> un.ptr.tp,B -> un.ptr.tp))
//递归判断表头节点是否相等,表尾节点是否相等
return TRUE;
else
return FALSE;
}
}
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式