已知两个单链表,编写算法找出两个单链表的公共节点(C语言版)

要找出两个单链表的公共节点,可以使用以下算法:

  1. 遍历第一个链表,将链表中的每个节点的地址存储在一个哈希表中。
  2. 遍历第二个链表,对于每个节点,检查它是否在哈希表中存在。
  3. 如果存在,则该节点就是两个链表的公共节点。
  4. 如果遍历完第二个链表都没有找到公共节点,则说明两个链表没有公共节点。

    #include <stdio.h>
    #include <stdlib.h>

    // 定义链表节点结构
    struct ListNode {
        int val;
        struct ListNode* next;
    };

    // 创建链表节点
    struct ListNode* createNode(int val) {
        struct ListNode* newNode = (struct ListNode*)malloc(sizeof(struct ListNode));
        newNode->val = val;
        newNode->next = NULL;
        return newNode;
    }

    // 找出两个链表的公共节点
    struct ListNode* findCommonNode(struct ListNode* head1, struct ListNode* head2) {
        // 创建哈希表
        int hash[10000] = {0};

        // 遍历第一个链表,将节点地址存储在哈希表中
        struct ListNode* current = head1;
        while (current != NULL) {
           

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值