题解 | #反转链表#

反转链表

http://www.nowcoder.com/practice/75e878df47f24fdc9dc3e400ec6058ca

/**

  • struct ListNode {
  • int val;
  • struct ListNode *next;
  • };
  • C语言声明定义全局变量请加上static,防止重复定义 */

/** *

  • @param pHead ListNode类

  • @return ListNode类 / struct ListNode ReverseList(struct ListNode* pHead ) { struct ListNode *pre=NULL,*temp=NULL; struct ListNode *cur=pHead; while(cur!=NULL) {

     temp=cur->next;//保存当前结点的下一个结点的值,防止链表断开时找不到下一个结点
     cur->next=pre;//让cur指向pre
     pre=cur;//pre向前移动一步到cur的位置
     cur=temp;//cur向前移动一步到cur的下一个结点的位置
    

    } return pre;//循环结束时pre指向链表反转后头结点的位置

}

全部评论

相关推荐

09-13 17:25
亲切的00后在笔试:我也遇到了,所以我早他一步查看图片
点赞 评论 收藏
分享
09-24 18:30
已编辑
长春工业大学 产品经理
小肥罗:HR就是好人的缩写哈哈哈哈
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务