• 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. }

  • 相关阅读:
    Linux虚拟机能ping通开发板的网络环境配置
    jmeter压力测试指标解释
    如何在WIndows虚拟机安装 macOS 黑苹果系统?
    一网打尽Mac上的软件套装 - Omi特别篇(附演示视频)
    数据结构:最全的名词解释
    vite项目、vue-cli项目环境配置
    【前端】常用属性及实例
    14道高频手写JS面试题及答案,巩固你的JS基础
    AI+教育的结合
    微信小程序经纬度转化为具体位置(逆地址解析)
  • 原文地址:https://blog.csdn.net/stay_awake__/article/details/126900126