求Java中比较两个广义表是否相等的代码模版

 我来答
育知同创教育
2016-04-25 · 百度知道合伙人官方认证企业
育知同创教育
1【专注:Python+人工智能|Java大数据|HTML5培训】 2【免费提供名师直播课堂、公开课及视频教程】 3【地址:北京市昌平区三旗百汇物美大卖场2层,微信公众号:yuzhitc】
向TA提问
展开全部
试编写判别两个广义表是否相等的递归算法。
广义表类型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;
}
}
追问
这好像是C语言的。。。我要的是Java
追答
但算法可以参考啊,你难道不会自己改吗
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式