环形链表、环形链表 II、有效的括号​​​​​​​(leetcode)

这篇具有很好参考价值的文章主要介绍了环形链表、环形链表 II、有效的括号​​​​​​​(leetcode)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、环形链表

方法(快慢指针):

二、环形链表 II

三、有效的括号


一、环形链表

给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。

如果链表中存在环 ,则返回 true 。 否则,返回 false 。

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

方法(快慢指针):

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

我们定义两个指针,一快一慢。慢指针每次只移动一步,而快指针每次移动两步。初始时,慢指针和快指针都在位置 head出发。这样一来,如果在移动的过程中,快指针反过来追上慢指针,就说明该链表为环形链表。否则快指针将到达链表尾部,该链表不为环形链表。

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
bool hasCycle(struct ListNode *head) {
    struct ListNode* slow = head,*fast = head;
    while(fast && fast->next)
    {
        slow = slow->next;
        fast = fast->next->next;
        if(slow == fast)
        {
            return true;
        }
    }
    return false;
}

时间复杂度:O(N)O(N)O(N),其中 NNN 是链表中的节点数。

当链表中不存在环时,快指针将先于慢指针到达链表尾部,链表中每个节点至多被访问两次。

当链表中存在环时,每一轮移动后,快慢指针的距离将减小一。而初始距离为环的长度,因此至多移动 NNN 轮。

空间复杂度:O(1)O(1)O(1)。我们只使用了两个指针的额外空间。

二、环形链表 II

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

给定一个链表的头节点  head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos 是 -1,则在该链表中没有环。注意:pos 不作为参数进行传递,仅仅是为了标识链表的实际情况。

不允许修改 链表。

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

快慢指针:

此题解题思路同上一题

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
struct ListNode *detectCycle(struct ListNode *head) {
    struct ListNode* slow = head,*fast = head;
    while(fast && fast->next)
    {
        slow = slow->next;
        fast = fast->next->next;
        //推到的一个结论:一个指针从相遇点开始走,一个指针从head走,他们会在入口点相遇
        if(slow == fast)
        {
            struct ListNode* meet = slow;
            while(head != meet)
            {
                head = head->next;
                meet = meat->next;
            }
            return meet;
        }
    }
    return NULL;
}

三、有效的括号

此题C语言不方便解释,只讲解思路

给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

1、左括号必须用相同类型的右括号闭合。
2、左括号必须以正确的顺序闭合。
3、每个右括号都有一个对应的相同类型的左括号。

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

    typedef char STDataType;
    typedef struct Stack
    {
        STDataType* a;
        int top;
        int capacity;
    }ST;

    void StackInit(ST* ps)
    {
        ps->a = (STDataType*)malloc(sizeof(STDataType) * 4);
        if (ps->a == NULL)
        {
            printf("malloc fail\n");
            exit(-1);
        }
        ps->capacity = 4;
        ps->top = 0;
    }
    void StackDestroy(ST* ps)
    {
        assert(ps);
        free(ps->a);
        ps->a = NULL;
        ps->top = ps->capacity = 0;
    }

    //入栈
    void StackPush(ST* ps, STDataType x)
    {
        assert(ps);

        //满了 -> 增容
        if (ps->top == ps->capacity)
        {
            STDataType* tmp = realloc(ps->a, ps->capacity * 2 * sizeof(int));
            if (tmp == NULL)
            {
                printf("realloc fail\n");
                exit(-1);
            }
            else {
                ps->a = tmp;
                ps->capacity *= 2;
            }
        }

        ps->a[ps->top] = x;
        ps ->top++;
    }

    //出栈
    void StackPop(ST* ps)
    {
        assert(ps);
        //ps->a[ps->top - 1] = 0;
        //此处有两种情况:
        //一、ps->a[ps->top - 1]本身就是0
        //二、ps->a[ps->top - 1]的数据类型不是int,是其他数据类型

        assert(ps->top > 0);
        //栈空了,调用Pop,直接中止程序报错

        ps->top--;


    }


    STDataType StackTop(ST* ps)
    {
        assert(ps);
        //栈空了,调用Top,直接中止程序报错
        assert(ps->top > 0);

        return ps->a[ps->top - 1];
    }

    bool StackEmpty(ST* ps)
    {
        assert(ps);

        return ps->top == 0;
    }

函数内部使用了一个名为ST的栈数据结构,并通过调用StackInit函数进行初始化。栈用于存储左括号({[(),以便后续与右括号进行匹配。

代码的主要逻辑是一个while循环,遍历输入字符串s中的每个字符,直到遇到字符串的结束符\0。在循环中,根据当前字符的不同情况进行处理:

  1. 如果当前字符是左括号({[(),则将其推入栈中,并移动指针s指向下一个字符。

  2. 如果当前字符是右括号(}])),则进行以下操作:

    • 首先检查栈是否为空,如果为空,则说明没有匹配的左括号,直接返回false表示字符串无效。

    • 如果栈不为空,则取出栈顶元素(即最近推入的左括号),并与当前右括号进行匹配。

    • 如果匹配成功(即左括号和右括号匹配),则将栈顶元素弹出,并移动指针s指向下一个字符。

    • 如果匹配失败,则直接返回false表示字符串无效。

  3. 如果当前字符不是括号,则直接跳过该字符。

循环结束后,检查栈是否为空。如果栈为空,则说明所有左括号都与右括号成功匹配,返回true表示字符串有效;否则返回false表示字符串无效。

最后,在返回结果之前,调用StackDestroy函数销毁栈,释放相关资源。

bool isValid(char* s) {
    ST st;
    StackInit(&st);
    while (*s != '\0')
    {
        switch (*s)
        {
        case'{':
        case'[':
        case'(':
        {
            StackPush(&st, *s);
            ++s;
            break;
        }
        case'}':
        case']':
        case')':
        {
            if (StackEmpty(&st))
            {
                StackDestroy(&st);
                return false;
            }
            char top = StackTop(&st);
            StackPop(&st);
            //不匹配
            if ((*s == '}' && top != '{')
                || (*s == ']' && top != '[')
                || (*s == ')' && top != '('))
            {
                return false;
            }
            else  //匹配
            {
                ++s;
            }
            break;
        }
        default:
            break;
        }
    }

    bool ret = StackEmpty(&st);
    StackDestroy(&st);
    return ret;
}

今天就先到这了!!!

环形链表、环形链表 II、有效的括号​​​​​​​(leetcode),链表,leetcode,linux

看到这里了还不给博主扣个:
⛳️ 点赞☀️收藏 ⭐️ 关注!

你们的点赞就是博主更新最大的动力!
有问题可以评论或者私信呢秒回哦。文章来源地址https://www.toymoban.com/news/detail-766304.html

到了这里,关于环形链表、环形链表 II、有效的括号​​​​​​​(leetcode)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • LeetCode:142. 环形链表 II

    🍎道阻且长,行则将至。🍓 🌻算法,不如说它是一种思考方式🍀 算法专栏: 👉🏻123 题目描述 :给定一个链表的头节点 head ,返回链表开始 入环的第一个节点 。 如果链表无环,则返回 null 。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在

    2024年02月07日
    浏览(45)
  • LeetCode刷题:142. 环形链表 II

    题目: 是否独立解决: 否,参考了解题思路解决问题,思考了用快慢指针,栈,统计链表数量定位尾巴节点(因为是环形链表所以是死循环,链表数量用while循环统计不出来)都没解决 解题思路:这题其实和环形链表一样的解题思路,用哈希set将数据都存储进去,如果发现

    2024年01月21日
    浏览(42)
  • ​LeetCode解法汇总142. 环形链表 II

    https://github.com/September26/java-algorithms 给定一个链表的头节点   head  ,返回链表开始入环的第一个节点。  如果链表无环,则返回  null 。 如果链表中有某个节点,可以通过连续跟踪  next  指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 

    2024年02月14日
    浏览(42)
  • [LeetCode]-160. 相交链表-141. 环形链表-142.环形链表II-138.随机链表的复制

    目录 160.相交链表  题目 思路 代码  141.环形链表  题目 思路 代码 142.环形链表II 题目 思路 代码 160. 相交链表 - 力扣(LeetCode) https://leetcode.cn/problems/intersection-of-two-linked-lists/description/ 给你两个单链表的头节点  headA  和  headB  ,请你找出并返回两个单链表相交的起始节点

    2024年02月05日
    浏览(52)
  • leetcode 141.环形链表 I - 142.环形链表 II 代码及指针相遇证明问题

    给你一个链表的头节点 head ,判断链表中是否有环。如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 如果链表中存在环 ,则返回 true 。 否则,返回 false 。 思路: 快慢指针问题 。我们可以声明一个 fast 指针(一次走两步),声明一个 slow

    2024年02月12日
    浏览(64)
  • LeetCode[141] [142] 环形链表I II

    141. 环形链表 - 力扣(LeetCode) 142. 环形链表 II - 力扣(LeetCode) 题解: 快慢指针题 从head开始,一个快指针,一次前进两步,一个慢指针,一次走一步 如果没有环,则快指针首先到达链表尾部, 如果有环,快慢指针肯定能相遇即fast=slow 141代码: 对于142需要环的起点,需要

    2024年02月04日
    浏览(46)
  • 【LeetCode 算法】Linked List Cycle II 环形链表 II

    给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从

    2024年02月14日
    浏览(44)
  • 【代码随想录 | Leetcode | 第七天】链表 | 链表相交 | 环形链表 II

    欢迎来到小K的Leetcode|代码随想录|专题化专栏,今天将为大家带来链表相交和环形链表 II的分享 ✨ ✨题目链接点这里 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。 图示两个链表在节点 c1 开始相交:

    2024年02月17日
    浏览(47)
  • 代码随想录 Leetcode142. 环形链表 II

            双指针解决百分之99的链表题

    2024年01月19日
    浏览(46)
  • 【刷题专栏—突破思维】LeetCode 142. 环形链表 II

    前言 :本篇博客将讲解三个OJ题,前两个作为铺垫,最后完成环形链表的节点的寻找 题目链接:LeetCode—相交链表 题目描述: 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。 图示两个链表在节

    2024年02月05日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包