C语言笔记32 •单链表经典算法OJ题-4.查找链表的中间结点•

1.问题

给你单链表的头结点 head ,请你找出并返回链表的中间结点。

如果有两个中间结点,则返回第二个中间结点。

2.代码实现(快慢指针)

//4.查找链表的中间结点
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>


typedef int SLTDataType;

typedef struct SListnode
{
	SLTDataType val;
	struct SListnode* next;
}ListNode;

ListNode* createNode(SLTDataType val)
{
	ListNode* newnode = (ListNode*)malloc(sizeof(ListNode));
	if (newnode == NULL)
	{
		perror("malloc");
		exit(1);
	}
	newnode->val = val;
	newnode->next = NULL;
	return newnode;
}



struct ListNode* middleNode(struct ListNode* head)
{
	if (head == NULL)
	{
		return head;
	}
	ListNode* slow, * fast;
	slow = fast= head;
	while (fast && fast->next)
	{
		slow = slow->next;
		fast = fast->next->next;
	}
	return slow;
}

int main()
{
	ListNode* node1, * node2, * node3, * node4, * node5, * node6;

	node1 = createNode(1);
	node2 = node1->next = createNode(2);
	node3 = node2->next = createNode(3);
	node4 = node3->next = createNode(4);
	node5 = node4->next = createNode(5);
	//node6 = node5->next = createNode(6);//创建一个链表

	ListNode* node = middleNode(node1);
	printf("%d", node->val);

	return 0;
}

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-12 13:24:01       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-12 13:24:01       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-12 13:24:01       57 阅读
  4. Python语言-面向对象

    2024-07-12 13:24:01       68 阅读

热门阅读

  1. docker 常用命令

    2024-07-12 13:24:01       24 阅读
  2. Redis的五种数据类型 #系统架构设计师#

    2024-07-12 13:24:01       24 阅读
  3. netstat 和ss命令

    2024-07-12 13:24:01       20 阅读
  4. 标准盒模型和怪异盒子模型的区别

    2024-07-12 13:24:01       21 阅读
  5. flink 配置表

    2024-07-12 13:24:01       29 阅读
  6. 无障碍快捷方式图标

    2024-07-12 13:24:01       25 阅读
  7. 每天一个数据分析题(四百二十三)- 置信区间

    2024-07-12 13:24:01       18 阅读