姜肆爷 2021-09-16 15:07 采纳率: 76%
浏览 43
已结题

数据结构与算法 带头结点的链式表的按值查找操作

正确代码为:


Position Find( List L, ElementType X )
{
    Position p = L; /* p指向L的第1个结点 */

    while ( p && p->Data!=X )
        p = p->Next;

    /* 下列语句可以用 return p; 替换 */
    if ( p )  //写成:if( p->Data == X) 时会编译错误
        return p;
    else
        return ERROR;

}

我想问一下,为啥当我的条件判断语句写成:if( p->Data == X) 时会编译错误
而且为啥可以直接用 return p; 替换

  • 写回答

2条回答 默认 最新

  • 快乐鹦鹉 2021-09-16 15:09
    关注

    你得先确保p不为空,才能判断p->Data==x啊。
    一旦p移动到最后一个节点,那么p = p->Next就是NULL啦。没有p的判断,p->Data操作就崩溃了
    你函数的目的是找到值为x的节点的位置,while循环结束的条件是p为空,或者p的值就是x,所以当p不为空时,那么自然p的值就是x,就是函数要找的节点,直接return p正确啊

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 9月24日
  • 已采纳回答 9月16日
  • 创建了问题 9月16日

悬赏问题

  • ¥15 win7系统进入桌面过一秒后突然黑屏
  • ¥15 有一台三相异步电动机 M1控制一个小车,有四个控制按钮,一个复位、一个启动、一个停止,还有一个急停,两个行程开关分别为上限位和下限位。 上限位。 下限位。
  • ¥30 backtrader对于期货交易的现金和资产计算的问题
  • ¥15 求C# .net4.8小报表工具
  • ¥15 安装虚拟机时出现问题
  • ¥15 Selenium+docker Chrome不能运行
  • ¥15 mac电脑,安装charles后无法正常抓包
  • ¥18 visio打开文件一直显示文件未找到
  • ¥15 请教一下,openwrt如何让同一usb储存设备拔插后设备符号不变?
  • ¥50 使用quartz框架进行分布式任务定时调度,启动了两个实例,但是只有一个实例参与调度,另外一个实例没有参与调度,不知道是为什么?请各位帮助看一下原因!!