0
点赞
收藏
分享

微信扫一扫

推荐:用动画的形式呈现解LeetCode题目的思路(github上25000多star)

前些日子推荐了一个仓库,把常见算法用python语言实现了(​​见文章​​),近日在github上发现另外一个25000多star的仓库,用动画的形式呈现解LeetCode题目的思路,非常值得推荐。

仓库说明

这个仓库用Java语言实现了绝大部分算法,大部分有动画演示,非常适合解题思路整理,也适合教学。

仓库地址:

​​https://github.com/MisterBooo/LeetCodeAnimation​​

内容说明

包含了常见的算法的python实现,如二叉树、排序、查找等等。这些是算法工程师必须掌握的技能。

文件目录

推荐:用动画的形式呈现解LeetCode题目的思路(github上25000多star)_github

leecode的题目的解答和动画演示

推荐:用动画的形式呈现解LeetCode题目的思路(github上25000多star)_github_02

图:来源于 LeetCode 上第 23 号问题:合并 K 个排序链表

典型代码

(LeetCode 上第 23 号问题):

class Solution {
public ListNode mergeKLists(ListNode[] lists){
if(lists.length == 0)
return null;
if(lists.length == 1)
return lists[0];
if(lists.length == 2){
return mergeTwoLists(lists[0],lists[1]);
}

int mid = lists.length/2;
ListNode[] l1 = new ListNode[mid];
for(int i = 0; i < mid; i++){
l1[i] = lists[i];
}

ListNode[] l2 = new ListNode[lists.length-mid];
for(int i = mid,j=0; i < lists.length; i++,j++){
l2[j] = lists[i];
}

return mergeTwoLists(mergeKLists(l1),mergeKLists(l2));

}
public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
if (l1 == null) return l2;
if (l2 == null) return l1;

ListNode head = null;
if (l1.val <= l2.val){
head = l1;
head.next = mergeTwoLists(l1.next, l2);
} else {
head = l2;
head.next = mergeTwoLists(l1, l2.next);
}
return head;
}
}

总结

近日在github上发现一个25000多star的仓库,用动画的形式呈现解LeetCode题目的思路,非常值得推荐。

仓库地址:

​​https://github.com/MisterBooo/LeetCodeAnimation​​


举报

相关推荐

0 条评论