设为首页 加入收藏

TOP

查找单链表的中点
2014-11-23 20:16:36 来源: 作者: 【 】 浏览:6
Tags:查找 单链表 中点

给定一个单链表如何高效的找到链表的中点,要求算法复杂度O(N),如果读者遇到过这样的问题,那么这个问题就迎刃而解了,验证链表是否有环的问题,使用快慢指针变量链表,同理中点问题也可以使用快慢指针实现,慢指针一次移动一个节点,快节点一次移动两个节点,快指针到达终点时,慢指针指向中点。

LinkNode *FindMid(LinkNode *p){
        if(p == NULL){
                return NULL;
        }
        LinkNode *fast = p;
        LinkNode *slow = p;
        while(fast && fast->next){
                fast = fast->next->next;
                slow = slow->next;
        }
        return slow;
}

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇hdu 1548 A strange lift 下一篇STM32F103 TIM1输出PWM设置

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·C 内存管理 | 菜鸟教 (2025-12-26 20:20:37)
·如何在 C 语言函数中 (2025-12-26 20:20:34)
·国际音标 [ç] (2025-12-26 20:20:31)
·微服务 Spring Boot (2025-12-26 18:20:10)
·如何调整 Redis 内存 (2025-12-26 18:20:07)