【力扣练习题】C语言答案

【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;
        }        
    }
}
相关推荐
No0d1es3 小时前
电子学会青少年软件编程(C/C++)5级等级考试真题试卷(2024年6月)
c语言·c++·算法·青少年编程·电子学会·五级
大阳1235 小时前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验
Swift社区5 小时前
Swift 实战:实现一个简化版的 Twitter(LeetCode 355)
leetcode·swift·twitter
FPGA7 小时前
探讨4B/5B编码、8B/10B编码区别以及FPGA实现
数据结构
秋难降7 小时前
线段树的深度解析(最长递增子序列类解题步骤)
数据结构·python·算法
Peter_Deng.7 小时前
Linux 下基于 TCP 的 C 语言客户端/服务器通信详解(三个示例逐步进阶)
服务器·c语言·网络
John.Lewis9 小时前
数据结构初阶(13)排序算法-选择排序(选择排序、堆排序)(动图演示)
c语言·数据结构·排序算法
AI小白的Python之路10 小时前
数据结构与算法-排序
数据结构·算法·排序算法
一只鱼^_10 小时前
牛客周赛 Round 105
数据结构·c++·算法·均值算法·逻辑回归·动态规划·启发式算法
火车叨位去194911 小时前
力扣top100(day04-05)--堆
算法·leetcode·职场和发展