本文主要是介绍LeetCode例题讲解:876.链表的中间结点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
给你单链表的头结点 head
,请你找出并返回链表的中间结点。
如果有两个中间结点,则返回第二个中间结点。
示例 1:
输入:head = [1,2,3,4,5] 输出:[3,4,5] 解释:链表只有一个中间结点,值为 3 。
示例 2:
输入:head = [1,2,3,4,5,6] 输出:[4,5,6] 解释:该链表有两个中间结点,值分别为 3 和 4 ,返回第二个结点。
该代码主要讲解了c语言链表的应用,首先先遍历链表,求出链表的长度
struct ListNode* middleNode(struct ListNode* head) {int length;for(struct ListNode* curr = head;curr != NULL;curr = curr->next){printf("%d ",curr->val);length++;}printf("%d",length);return NULL;
}
之后就可以创建新的链表头,并使其一点点移动到length/2的位置,之后将其回传
struct ListNode* middleNode(struct ListNode* head) {int length = 0;for(struct ListNode* curr = head;curr != NULL;curr = curr->next){length++;}struct ListNode* result = head;for(int i = 0 ; i < length/2; i++){result = result->next;}return result;
}
这篇关于LeetCode例题讲解:876.链表的中间结点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!