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

568 阅读6分钟

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

仓库说明

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

仓库地址:\

github.com/MisterBooo/…

内容说明

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

文件目录

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

图:来源于 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题目的思路,非常值得推荐。

仓库地址:\

github.com/MisterBooo/…

请关注和分享↓↓↓\

本站的知识星球(黄博的机器学习圈子)ID:92416895\

目前在机器学习方向的知识星球排名第一

往期精彩回顾\