voud retract(void)
{
struct Node *Q;
Q=head->next;
while(Q->next!=p)
Q=Q->next;
p=Q;
}
这段代码 他注释是回退一个字符
可是我看一看感觉是说:
Q不是head的下下个就p=head的下下个结点
那 不就不是 回退一个字符了么
麻烦知道我错哪的给我讲一下~
有关C++指针的一个小问题
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
3条回答 默认 最新
SeaTalks 2016-10-17 08:38关注其实建议你规范一下代码,因为很多时候代码不规范的话,很容易让人犯错。上面的代码,等价于:
void retract ( void ) { struct Node *Q; Q = head->next; while ( Q->next != p) //整个循环是为了找到p的前一个字符,因为结束的条件是 Q->next == p,所以Q是p的前一个 { Q = Q->next; } p=Q; //指针p指向了前一个,就是回退了嘛 }本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报