• 160.相交链表


    题目来源:力扣https://leetcode.cn/problems/intersection-of-two-linked-lists/

    题目简介: 

    找到两个相交链表的起始结点,并返回,如果没找到就返回null

    思路1:

    哈希集合的思路很简单,重要的是哈希表代码的完整实现。就是记录遍历a链表,记录玩,再记录b链表,比较哈希表中有没有,有的话后面的结点就都是重合部分,返回第一个相交结点,哈希表里没有的话就返回null

    代码段:

    1. /**
    2. * Definition for singly-linked list.
    3. //首先构造链表的结构体
    4. * struct ListNode {
    5. * int val;
    6. * struct ListNode *next;
    7. * };
    8. */
    9. //接着构造哈希集合的结构体,我们这个题只需要用哈希表做一个类似于容器的作用,所以可以考虑用哈希集合,不用考虑哈希表的键值对,只用考虑键值就行了。
    10. struct HashTable{
    11. struct ListNode *key;
    12. //在哈希表中我们必须要在结构体内定义一个操作句柄(什么叫操作句柄,其实我的理解比较特别一点,因为哈希表的操作使用属于开源文件,在c内部是本来没有的,所以在进行哈希表的一系列操作的时候我们需要引用操作句柄),UT_hash,定义的名称一般都是用hh,哈希表的初学者,可以用这题进行参考。
    13. UT_hash_handle hh;
    14. };
    15. struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {
    16. //这里我们先要创建一个哈希表,先令其为空
    17. struct HashTable *hashtable=NULL;
    18. 然后创建一个指针指向A链表的头结点
    19. struct ListNode *temp=headA;
    20. //先进行第一部分遍历,先一边遍历一边检查哈希表内有没有这个值,没有的话就放进去
    21. while(temp!=NULL){
    22. //这里创建临时变量
    23. struct HashTable *tmp;
    24. //然后在添加操作之前我们要进行查找操作,确保这个值在哈希表内没有
    25. 查找操作的模板就是这样HASH_FIND(hh,hashtable,&key,keylen,out)理解方面就是先确定好哈希表的名字,再确定要查找的值,要确定要查找的值就要知道这个值的地址,然后要知道长度,长度就是这个key的类型,然后out接收输出结果,如果找到,返回值的地址,没找到就返回NULL
    26. HASH_FIND(hh,hashtable,&temp,sizeof(struct HashTable*),tmp);
    27. if(tmp==NULL){
    28. tmp=malloc(sizeof(struct HashTable));
    29. tmp->key=temp;
    30. HASH_ADD(hh,hashtable,key,sizeof(struct HashTable*),tmp);
    31. }
    32. temp=temp->next;
    33. }
    34. temp=headB;
    35. //然后就是遍历b链表来查找重复值,所以就只需要一个find操作就行
    36. while(temp!=NULL){
    37. struct HashTable *tmp;
    38. HASH_FIND(hh,hashtable,&temp,sizeof(struct HashTable*),tmp);
    39. if(tmp!=NULL){
    40. return temp;
    41. }
    42. temp=temp->next;
    43. }
    44. return NULL;
    45. }

  • 相关阅读:
    35、Flink 的 Formats 之CSV 和 JSON Format
    win10专业版驱动开发
    2023计算机毕业设计SSM最新选题之java企业会议室预约系统的设计与实现3j969
    1000套web前端期末大作业 HTML+CSS+JavaScript网页设计实例 企业网站制作【建议收藏】
    使用scss简化媒体查询
    C# SolidWorks二次开发---工程图中心标记(Center Marks)
    如何通过Python进行图片批量下载?
    Kaldi安装(Linux环境)
    element ui 中 el-table选中数据
    【LeetCode】655. 输出二叉树
  • 原文地址:https://blog.csdn.net/stay_awake__/article/details/126900126