判断链表是否有交点若有找出交点

本文介绍了一种判断两个链表是否相交并找到交点的算法实现。通过两次遍历,首先确定两链表是否有交点,再找出具体交点。此外,还附带了一个多进程环境下打印字符数量的问题及解答。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

.判断两个链表是否相交,若相交,求交点。(假设链表不带环)

ListNode *InstersecNode(ListNode *pHead1, ListNode *pHead2)
{
    bool flag = IsIntersec(pHead1, pHead2);
    if (!flag)
        return nullptr;
    ListNode *pNode1 = pHead1;
    ListNode *pNode2 = pHead2;
    while (pNode1&&pNode2)
    {
        pNode1 = pNode1->_pNext;
        pNode2 = pNode2->_pNext;
    }
    if (pNode1 == nullptr)
        pNode1 = pHead1;
    else
        pNode2 = pHead2;
    while (pNode1&&pNode2)
    {
        if (pNode1 == pNode2)
            return pNode1;
        pNode1 = pNode1->_pNext;
        pNode2 = pNode2->_pNext;
    }
    return nullptr;
}
bool IsIntersec(ListNode *pHead1, ListNode *pHead2)
{
    if (pHead1 == nullptr&&pHead2 == nullptr)
        return false;
    while (pHead1->_pNext)
        pHead1 = pHead1->_pNext;
    while (pHead2->_pNext)
        pHead2 == pHead2->_pNext;
    if (pHead1 == pHead2)
        return true;
    else
        return false;
}

判断两个链表是否相交,若相交,求交点。

见上一篇博客
http://blog.youkuaiyun.com/gjggj/article/details/75213010

请问下面的程序一共输出多少个“-”?

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>

int main(void)
{
   int i;
   for(i=0; i<2; i++){
      fork();
      printf("-");
   }

   wait(NULL);
   wait(NULL);

   return 0;
}

8个
详解见陈浩的博客
http://coolshell.cn/articles/7965.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值