我必须重写这段假定布尔表达式短路计算的代码段:
while ((p!=NULL) && (p->val != v)) p=p->next;这样,它可以执行完全相同的任务,而不需要假设布尔表达式的短路计算。有人能帮我解决这个问题吗?
我在互联网上搜索过,但我得到的只是短路评估和非短路评估的区别,但我在重写其中一种或另一种时找不到任何东西让它们做同样的事情。这是为了考试复习(而不是家庭作业),所以这将是很好的帮助别人解决它,所以我至少知道如何做到这一点,为简单的代码。欢迎解释:-)
发布于 2014-04-03 08:53:26
while(true)
{
if (p == NULL)
break;
if (p->val == v)
break;
p = p->next;
}一些解释:原始代码依赖于短路评估.如果p->val != v的计算结果为false,则不会对p!=NULL进行评估。如果它总是计算第二个表达式,这可能会导致访问冲突。如果不使用短路&&操作符,则需要确保在代码中只对p->val进行评估。
发布于 2014-04-03 08:58:58
只需将NULL检查和对p成员的访问拆分为两个语句即可。
短路评估意味着,在一个和条件,如果第一个操作数是假的,代码不麻烦检查第二个,因为它已经知道结果是“假”。
我想说:
val = null;
while (p != null && val != v)
{
p = p->next();
val = p->val;
}https://stackoverflow.com/questions/22831770
复制相似问题