[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-4164":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":16,"stars7d":17,"stars30d":18,"stars90d":16,"forks30d":16,"starsTrendScore":16,"compositeScore":19,"rankGlobal":10,"rankLanguage":10,"license":10,"archived":20,"fork":20,"defaultBranch":21,"hasWiki":22,"hasPages":20,"topics":23,"createdAt":10,"pushedAt":10,"updatedAt":32,"readmeContent":33,"aiSummary":34,"trendingCount":16,"starSnapshotCount":16,"syncStatus":17,"lastSyncTime":35,"discoverSource":36},4164,"awesome-java-leetcode","Blankj\u002Fawesome-java-leetcode","Blankj",":crown: LeetCode of algorithms with java solution(updating).","",null,"Java",8700,1693,368,5,0,2,3,40.69,false,"master",true,[24,25,26,27,28,29,30,31],"algorithm","algorithms","datastructure","datastructures","facebook","leetcode","leetcode-java","leetcode-solutions","2026-06-12 02:00:59","# awesome-java-leetcode\n\n我如今是一名 Android Developer，大学的我曾是一名 ACMer，我一直认为数据结构和算法是作为一名程序员必须掌握和善于利用的，为了不让数据结构和算法淡出我的记忆，所以我打算重拾 LeetCode 之 Algorithm，语言选择的是 Java，题库会一点点完善起来，按简单，中等，困难分类，相应难度下按题号排序，源代码在 [src][src] 目录中，相关解题都在 [note][note] 目录中，想要学习数据结构和算法或打算刷 LeetCode 的小伙伴们欢迎 star 哦。\n\n如今有机会面试 Facebook，附上 LeetCode 上 Facebook 的面试题目序号，希望可以帮助到以后想入 Facebook 的小伙伴:-)\n\n```\n1,10,13,15,17,20,23,25,26,28,33,38,43,44,49,50,56,57,67,68,69,71,75,76\n78,79,80,85,88,90,91,98,102,117,121,125,127,128,133,139,146,157,158,161\n168,173,200,206,208,209,210,211,215,218,221,234,235,236,238,252,253,257\n261,265,269,273,274,275,277,278,282,283,285,286,297,301,311,314,325,334\n341,377,380,398,404,410,461,477,494,523,525,534,535,543,554\n```\n\n如果想知道更多公司 LeetCode 面试题，可以参看 [Companies.md][companies]。\n\n附上镇楼诗：\n\n> 明有科举八股，今有 LeetCode。  \n> 八股定格式而取文采心意，LeetCode 定题目且重答案背诵。  \n> 美其名曰：\"practice makes perfect.\"  \n> 为何今不如古？  \n> 非也非也，  \n> 科举为国取士，LeetCode 为 Google 筛码工，各取所需也。  \n\n## Easy\n\n| #    | Title                                                             | Tag                                               |\n| :--- | :---------------------------------------------------------------- | :------------------------------------------------ |\n| 1    | [Two Sum][0001]                                                   | Array, Hash Table                                 |\n| 7    | [Reverse Integer][0007]                                           | Math                                              |\n| 9    | [Palindrome Number][0009]                                         | Math                                              |\n| 13   | [Roman to Integer][0013]                                          | Math, String                                      |\n| 14   | [Longest Common Prefix][0014]                                     | String                                            |\n| 16.11| [跳水板(Diving Board LCCI)][16_11]                                 | 递归、记忆化                                       |\n| 20   | [Valid Parentheses][0020]                                         | Stack, String                                     |\n| 21   | [Merge Two Sorted Lists][0021]                                    | Linked List                                       |\n| 26   | [Remove Duplicates from Sorted Array][0026]                       | Array, Two Pointers                               |\n| 27   | [Remove Element][0027]                                            | Array, Two Pointers                               |\n| 28   | [Implement strStr()][0028]                                        | Two Pointers, String                              |\n| 35   | [Search Insert Position][0035]                                    | String                                            |\n| 38   | [Count and Say][0038]                                             | String                                            |\n| 53   | [Maximum Subarray][0053]                                          | Array, Divide and Conquer, Dynamic Programming    |\n| 58   | [Length of Last Word][0058]                                       | String                                            |\n| 66   | [Plus One][0066]                                                  | Array, Math                                       |\n| 67   | [Add Binary][0067]                                                | Math, String                                      |\n| 69   | [Sqrt(x)][0069]                                                   | Binary Search, Math                               |\n| 70   | [Climbing Stairs][0070]                                           | Dynamic Programming                               |\n| 83   | [Remove Duplicates from Sorted List][0083]                        | Linked List                                       |\n| 88   | [Merge Sorted Array][0088]                                        | Array, Two Pointers                               |\n| 100  | [Same Tree][0100]                                                 | Tree, Depth-first Search                          |\n| 101  | [Symmetric Tree][0101]                                            | Tree, Depth-first Search, Breadth-first Search    |\n| 104  | [Maximum Depth of Binary Tree][0104]                              | Tree, Depth-first Search                          |\n| 107  | [Binary Tree Level Order Traversal II][107]                       | Tree, Breadth-first Search                        |\n| 108  | [Convert Sorted Array to Binary Search Tree][0108]                | Tree, Depth-first Search                          |\n| 110  | [Balanced Binary Tree][0110]                                      | Tree, Depth-first Search                          |\n| 111  | [Minimum Depth of Binary Tree][0111]                              | Tree, Depth-first Search, Breadth-first Search    |\n| 112  | [Path Sum][0112]                                                  | Tree, Depth-first Search                          |\n| 118  | [Pascal's Triangle][0118]                                         | Array                                             |\n| 119  | [Pascal's Triangle II][0119]                                      | Array                                             |\n| 121  | [Best Time to Buy and Sell Stock][0121]                           | Array, Dynamic Programmin                         |\n| 122  | [Best Time to Buy and Sell Stock II][0122]                        | Array, Greedy                                     |\n| 543  | [Diameter of Binary Tree][0543]                                   | Tree                                              |\n\n## Medium\n\n| #    | Title                                                             | Tag                                               |\n| :--- | :---------------------------------------------------------------- | :------------------------------------------------ |\n| 2    | [Add Two Numbers][0002]                                           | Linked List, Math                                 |\n| 3    | [Longest Substring Without Repeating Characters][0003]            | Hash Table, Two Pointers, String                  |\n| 5    | [Longest Palindromic Substring][0005]                             | String, Dynamic Programming                       |\n| 6    | [ZigZag Conversion][0006]                                         | String                                            |\n| 8    | [String to Integer (atoi)][0008]                                  | Math, String                                      |\n| 11   | [Container With Most Water][0011]                                 | Array, Two Pointers                               |\n| 12   | [Integer to Roman][0012]                                          | Math, String                                      |\n| 15   | [3Sum][0015]                                                      | Array, Two Pointers                               |\n| 15   | [3Sum Closest][0016]                                              | Array, Two Pointers                               |\n| 17   | [Letter Combinations of a Phone Number][0017]                     | String, Backtracking                              |\n| 18   | [4Sum][0018]                                                      | Array, Hash Table, Two Pointers                   |\n| 19   | [Remove Nth Node From End of List][0019]                          | Linked List, Two Pointers                         |\n| 22   | [Generate Parentheses][0022]                                      | String, Backtracking                              |\n| 24   | [Swap Nodes in Pairs][0024]                                       | Linked List                                       |\n| 29   | [Divide Two Integers][0029]                                       | Math, Binary Search                               |\n| 33   | [Search in Rotated Sorted Array][0033]                            | Arrays, Binary Search                             |\n| 43   | [Multiply Strings][0043]                                          | Math, String                                      |\n| 49   | [Group Anagrams][0049]                                            | Hash Table, String                                |\n| 50   | [Pow(x, n)][0050]                                                 | Math, Binary Search                               |\n| 56   | [Merge Intervals][0056]                                           | Array, Sort                                       |\n| 63   | [不同路径 II(Unique Paths II)][0063]                               | 数组、动态规划                                      |\n| 209  | [长度最小的子数组(Minimum Size Subarray Sum)][0209]                 | 数组、双指针、二分查找                               |\n| 215  | [数组中的第K个最大元素(Kth Largest Element in an Array)][0215]       | 堆、分治算法                                       |\n| 554  | [Brick Wall][0554]                                                | Hash Table                                        |\n| 1014 | [最佳观光组合(Best Sightseeing Pair)][1014]                         | 数组                                              |\n\n## Hard\n\n| #    | Title                                                             | Tag                                               |\n| :--- | :---------------------------------------------------------------- | :------------------------------------------------ |\n| 4    | [Median of Two Sorted Arrays][0004]                               | Array, Binary Search, Divide and Conquer          |\n| 10   | [Regular Expression Matching][0010]                               | String, Dynamic Programming, Backtracking         |\n| 23   | [Merge k Sorted Lists][0023]                                      | Linked List, Divide and Conquer, Heap             |\n| 25   | [Reverse Nodes in k-Group][0025]                                  | Linked List                                       |\n| 30   | [Substring with Concatenation of All Words][0030]                 | Hash Table, Two Pointers, String                  |\n| 44   | [Wildcard Matching][0044]                                         | String, Dynamic Programming, Backtracking, Greedy |\n| 57   | [Insert Interval][0057]                                           | Array, Sort                                       |\n| 68   | [Text Justification][0068]                                        | String                                            |\n| 1028 | [从先序遍历还原二叉树(Recover a Tree From Preorder Traversal)][1028] | 树、深度优先搜索                                    |\n\n## 打个小广告\n\n欢迎加入我的小专栏「**[基你太美](https:\u002F\u002Fxiaozhuanlan.com\u002FBlankj)**」一起学习。\n\n\n[src]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Ftree\u002Fmaster\u002Fsrc\n[note]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Ftree\u002Fmaster\u002Fnote\n[companies]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002FCompanies.md\n\n[0001]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0001\u002FREADME.md\n[0007]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0007\u002FREADME.md\n[0009]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0009\u002FREADME.md\n[0013]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0013\u002FREADME.md\n[0014]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0014\u002FREADME.md\n[16_11]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F16_11\u002FREADME.md\n[0020]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0020\u002FREADME.md\n[0021]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0021\u002FREADME.md\n[0026]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0026\u002FREADME.md\n[0027]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0027\u002FREADME.md\n[0028]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0028\u002FREADME.md\n[0035]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0035\u002FREADME.md\n[0038]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0038\u002FREADME.md\n[0053]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0053\u002FREADME.md\n[0058]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0058\u002FREADME.md\n[0066]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0066\u002FREADME.md\n[0067]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0067\u002FREADME.md\n[0069]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0069\u002FREADME.md\n[0070]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0070\u002FREADME.md\n[0083]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0083\u002FREADME.md\n[0088]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0088\u002FREADME.md\n[0100]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0100\u002FREADME.md\n[0101]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0101\u002FREADME.md\n[0104]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0104\u002FREADME.md\n[0107]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0107\u002FREADME.md\n[0108]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0108\u002FREADME.md\n[0110]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0110\u002FREADME.md\n[0111]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0111\u002FREADME.md\n[0112]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0112\u002FREADME.md\n[0118]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0118\u002FREADME.md\n[0119]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0119\u002FREADME.md\n[0121]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0121\u002FREADME.md\n[0122]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0122\u002FREADME.md\n[0543]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0543\u002FREADME.md\n\n[0002]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0002\u002FREADME.md\n[0003]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0003\u002FREADME.md\n[0005]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0005\u002FREADME.md\n[0006]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0006\u002FREADME.md\n[0008]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0008\u002FREADME.md\n[0011]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0011\u002FREADME.md\n[0012]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0012\u002FREADME.md\n[0015]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0015\u002FREADME.md\n[0016]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0016\u002FREADME.md\n[0017]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0017\u002FREADME.md\n[0018]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0018\u002FREADME.md\n[0019]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0019\u002FREADME.md\n[0022]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0022\u002FREADME.md\n[0024]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0024\u002FREADME.md\n[0029]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0029\u002FREADME.md\n[0033]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0033\u002FREADME.md\n[0043]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0043\u002FREADME.md\n[0049]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0049\u002FREADME.md\n[0050]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0050\u002FREADME.md\n[0056]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0056\u002FREADME.md\n[0063]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0063\u002FREADME.md\n[0209]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0209\u002FREADME.md\n[0215]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0215\u002FREADME.md\n[0554]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0554\u002FREADME.md\n[1014]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F1014\u002FREADME.md\n\n[0004]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0004\u002FREADME.md\n[0010]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0010\u002FREADME.md\n[0023]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0023\u002FREADME.md\n[0025]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0025\u002FREADME.md\n[0030]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0030\u002FREADME.md\n[0044]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0044\u002FREADME.md\n[0057]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0057\u002FREADME.md\n[0068]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F0068\u002FREADME.md\n[1028]: https:\u002F\u002Fgithub.com\u002FBlankj\u002Fawesome-java-leetcode\u002Fblob\u002Fmaster\u002Fnote\u002F1028\u002FREADME.md\n","awesome-java-leetcode 是一个使用 Java 语言实现的 LeetCode 算法题解项目。该项目涵盖了从简单到困难级别的多种算法题目，每道题都配有详细的代码实现和解题思路说明，涉及数据结构、字符串处理、数组操作等多方面内容。所有源代码均存放在 src 目录下，并且在 note 目录中提供了相关解析文档。此外，还特别整理了 Facebook 面试中常见的 LeetCode 题目列表，为准备面试的同学提供参考。此项目非常适合希望提升编程能力、准备技术面试或对算法感兴趣的开发者学习与实践。","2026-06-11 02:58:49","top_language"]