【力扣练习题】C语言答案
创始人
2024-12-17 03:34:55
0

【21题,合并两个有序链表】
思路:递归:

1、如果q为NULL,p为NULL;返回NULL;

2、如果q为NULL,返回p;

3、如果p为NULL,返回 q;

4、判断两数大小,p小于等于q返回p,p->next递归调用函数

5、否则返回q,q->next递归调用函数

代码:
​ struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {     struct ListNode* p = list1;     struct ListNode* q = list2;          if(q==NULL && p==NULL)     {         return NULL;     }     else if(q==NULL)     {         return p;     }     else if(p==NULL)     {         return q;     }          if(p->val <= q->val)     {         p->next = mergeTwoLists(p->next,q);         return p;     }     q->next =  mergeTwoLists(p,q->next);       return q; }
思路:使用迭代的方法

1、定义头尾节点,

2、遍历判断两个链表的单个值,用尾插法将小的值代入链表

代码:
​ struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {     struct ListNode* p = list1;     struct ListNode* q = list2;     struct ListNode *tail = NULL;     struct ListNode *head = NULL;     if(q==NULL && p==NULL)     {         return NULL;     }     else if(q==NULL)     {         return p;     }     else if(p==NULL)     {         return q;     }       while(p != NULL && q!=NULL)     {         struct ListNode *pnew = (q->val <= p->val)? q:p;         if(head == NULL)         {             head = pnew;             tail = pnew;         }         else          {             tail->next = pnew;             tail = pnew;           }         if(q->val <= p->val)         {             q=q->next;         }         else         {             p= p->next;         } ​     }     tail->next = (q==NULL)?p:q;     return head; }
【环形链表】
思路:暴力求解

1、将所有遍历过的值全部替换为100001

2、判断如果遇到NULL则返回false

3、如果遇到大于100000的数则返回true;

代码:
/**  * Definition for singly-linked list.  * struct ListNode {  *     int val;  *     struct ListNode *next;  * };  */ bool hasCycle(struct ListNode *head) {     if(head == NULL)     {         return false;     }     struct ListNode *p = head;     int temp = 10000;     while(1)     {          p->val = 100001;         p = p->next;         if(p == NULL)         {             return false;             break;         }         else if(p->val > 100000)         {             return true;             break;         }             } }

相关内容

热门资讯

第四分钟方针!中至余干破解器,... 第四分钟方针!中至余干破解器,随意玩房卡辅助器透视(辅助)确实真的是有app(哔哩哔哩)一、随意玩房...
透视教程书!菠萝辅助器免费版的... 透视教程书!菠萝辅助器免费版的特点,飞驰娱乐软件科技(辅助)切实一直都是有神器(哔哩哔哩)1)飞驰娱...
透视阶段!pokermaste... 透视阶段!pokermaster修改器,AApoker工具果然是真的有辅助,7分钟教程(有挂秘籍)1...
6分钟手筋!衢州都莱辅助器开挂... 6分钟手筋!衢州都莱辅助器开挂,九游辅助真的假的(辅助)真是有挂安装(哔哩哔哩)1、衢州都莱辅助器开...
透视指引!约局吧德州真的存在透... 透视指引!约局吧德州真的存在透视吗,雀姬手游辅助脚本(辅助)本来真的是有技巧(哔哩哔哩)1、雀姬手游...
透视模块!wpk刷入池率脚本,... 透视模块!wpk刷入池率脚本,WPK方法都是真的是有下载,第6分钟教程(有挂助手)1、完成wpk刷入...
透视总结!竞技联盟透视插件,樱... 透视总结!竞技联盟透视插件,樱花之盛免费挂(辅助)真是有工具(哔哩哔哩)1.樱花之盛免费挂 选牌创建...
两分钟绝活儿!新樱花互娱源码,... 两分钟绝活儿!新樱花互娱源码,新星游辅助真的假的(辅助)一贯真的有插件(哔哩哔哩)1、全新机制【新星...
透视举措!hh poker辅助... 透视举措!hh poker辅助有用吗,HHpoker有用竟然是真的有插件,两分钟教程(有挂教程)1、...
透视项目!拱趴大菠萝机器人,情... 透视项目!拱趴大菠萝机器人,情怀江湖手游辅助(辅助)好像存在有技巧(哔哩哔哩)1、下载好情怀江湖手游...