求通过data域比较两个广义表是否相等的代码模板,Java的
1个回答
展开全部
试编写判别两个广义表是否相等的递归算法。
广义表类型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;
}
}
广义表类型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 广告
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件...
点击进入详情页
本回答由光点科技提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询