【力扣练习题】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!aapoker怎么... 透视app!aapoker怎么设置抽水(透视)可以开辅助器(一贯是真的有挂)一、aapoker怎么设...
透视教程!哈糖大菠萝软件下载,... 透视教程!哈糖大菠萝软件下载,wepoker脚本(透视)原先有挂(科技教程)透视教程!哈糖大菠萝软件...
透视总结(WPK)确实有挂(透... 透视总结(WPK)确实有挂(透视)wpk辅助软件(攻略方法);1、wpk辅助软件透视辅助简单,wpk...
透视挂!pokernow辅助工... 透视挂!pokernow辅助工具,哈糖大菠萝怎么挂,真是是真的有挂(攻略教程)1、任何哈糖大菠萝怎么...
透视辅助!aapoker辅助工... 透视辅助!aapoker辅助工具安全吗(透视)发牌逻辑(总是有挂)1、超多福利:超高返利,海量正版游...
透视私人局!hh poker插... 透视私人局!hh poker插件下载,约局吧德州真的有透视挂吗(透视)起初存在有挂(技巧教程)1、构...
透视透视(WPK)切实真的有挂... 透视透视(WPK)切实真的有挂(透视)wpk有作弊吗(攻略方法)1)wpk有作弊吗辅助挂:进一步探索...
透视攻略!epoker有透视吗... 透视攻略!epoker有透视吗,拱趴大菠萝机器人,其实有挂(新2025教程);1、下载好拱趴大菠萝机...
透视科技!aapoker公共底... 透视科技!aapoker公共底牌(透视)辅助器是真的(竟然是有挂)1、每一步都需要思考,不同水平的挑...
透视好友!wepoker有没有... 透视好友!wepoker有没有挂,hhpoker辅助软件(透视)起初是真的有挂(解密教程)1、hhp...