每日算法(精选)
精选每日算法,每日更新,提升算法能力,加强代码实现能力
蓝莓星冰乐
台上一分钟,台下十年功。欢迎各位大佬互三,本人一名普普通通的计算机爱好者
展开
-
每日算法2(翻转链表)
接着进入循环,我们选不探讨循环条件,先研究循环语句,n2的next要存储n1,就是为了使最后的链表的next的空,n1=n2,n2=n3,if(n3)n3=n3->, n1是整个链表,n2=n3是为了指向后面的元素,在将后面的元素插入到n1前面,然后再让n1是指向头节点,最后5就是新的头节点。先来讲下最简单的算法,创建一个新链表,将原链表的元素挨个头插到新链表上,就实现了顺序表的逆转,这里就不示例代码了,在之前的链表有提及。让n1指向空,n2指向头,n3指向head->next。原创 2024-09-25 23:58:26 · 235 阅读 · 4 评论 -
每日算法1(快慢指针)
那么这样写对吗,答案是对的,那么如果将他们翻转过来,写成fast->next&&fast还对吗,那就不对了,如果fast为空指针,对空指针进行解引用就会报错,还是要写成fast&&fast->next,因为当fast为空指针就结束了,不会进行fast的解引用,因此就不会发生报错。这是一道力扣的算法题,首先来读题,是删除链表的中间元素,先来分析一下题,链表一共有三种可能,第一种是空链表,第二种链表的个数是偶数,第三种是链表的个数是奇数,我们分别来对这三种情况讨论。另一种就是快慢指针,首先我们先定义两个指针,原创 2024-09-24 22:16:06 · 460 阅读 · 8 评论