鱼C论坛

 找回密码
 立即注册
查看: 2512|回复: 1

链表中的LocateElem函数问题

[复制链接]
发表于 2020-2-1 19:19:12 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
函数功能是:功能时查找e的结点位置
int LocateElem(LinkList L, ElemType e)
{
        if (ListEmpty(L)) {
                return ERROR;
        }
        LinkList p = L->next;
        int i = 1;
        while (p && p->data != e) {  //这里的循环条件 (p && p->data != e) 改成 (p->data != e && p),下面退出循环时就不会进入 if (!p) 这是为什么?
                p = p->next;
                i++;
        }
        if (!p) {
                printf("LocateElem failed: %d not found!\n", e);
                return FALSE;
        }
        return i;
}

这个问题很久以前就遇到过,今天又发现了,很困惑。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-2-8 19:43:47 | 显示全部楼层
if (!p) {
                printf("LocateElem failed: %d not found!\n", e);
                return FALSE;
        }
1)先分析这个if语句的进入条件,p需要为NULL才会进入。而p为NULL的时机应该是指针遍历完整个链表了。
2)再分析循环条件     (p && p->data != e) 与 (p->data != e && p)的区别
首先,两者的区别是短路逻辑中的先后执行不同,
(p && p->data != e) 是如果p为NULL,则 "p->data != e" 这一句就不执行,直接跳出while了。
(p->data != e && p)是如果找到了e,则判断p是否为NULL就不执行,直接跳出while了。
鉴于循环条件都只是做逻辑判断,不会影响具体的变量或指针,故在链表中,两者是相同的功能。

调试推荐用printf函数把p和p->data都打印出来,这样更加直观。

如有错误,请指出
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 03:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表