{"id":13398710,"url":"https://github.com/Blankj/awesome-java-leetcode","last_synced_at":"2025-03-14T02:31:31.599Z","repository":{"id":38711821,"uuid":"88524149","full_name":"Blankj/awesome-java-leetcode","owner":"Blankj","description":":crown: LeetCode of algorithms with java solution(updating).","archived":false,"fork":false,"pushed_at":"2020-12-10T15:20:21.000Z","size":512,"stargazers_count":8704,"open_issues_count":13,"forks_count":1725,"subscribers_count":373,"default_branch":"master","last_synced_at":"2024-10-29T15:39:19.838Z","etag":null,"topics":["algorithm","algorithms","datastructure","datastructures","facebook","leetcode","leetcode-java","leetcode-solutions"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Blankj.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null},"funding":{"github":null,"patreon":null,"open_collective":null,"ko_fi":null,"tidelift":null,"community_bridge":null,"liberapay":null,"issuehunt":null,"otechie":null,"custom":"https://raw.githubusercontent.com/Blankj/AndroidUtilCode/master/art/donate.png"}},"created_at":"2017-04-17T15:51:41.000Z","updated_at":"2024-10-29T11:37:06.000Z","dependencies_parsed_at":"2022-07-08T02:20:41.819Z","dependency_job_id":null,"html_url":"https://github.com/Blankj/awesome-java-leetcode","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Blankj%2Fawesome-java-leetcode","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Blankj%2Fawesome-java-leetcode/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Blankj%2Fawesome-java-leetcode/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Blankj%2Fawesome-java-leetcode/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Blankj","download_url":"https://codeload.github.com/Blankj/awesome-java-leetcode/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":243419072,"owners_count":20287805,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["algorithm","algorithms","datastructure","datastructures","facebook","leetcode","leetcode-java","leetcode-solutions"],"created_at":"2024-07-30T19:00:30.938Z","updated_at":"2025-03-14T02:31:31.571Z","avatar_url":"https://github.com/Blankj.png","language":"Java","readme":"# 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\u003e 明有科举八股，今有 LeetCode。  \n\u003e 八股定格式而取文采心意，LeetCode 定题目且重答案背诵。  \n\u003e 美其名曰：\"practice makes perfect.\"  \n\u003e 为何今不如古？  \n\u003e 非也非也，  \n\u003e 科举为国取士，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://xiaozhuanlan.com/Blankj)**」一起学习。\n\n\n[src]: https://github.com/Blankj/awesome-java-leetcode/tree/master/src\n[note]: https://github.com/Blankj/awesome-java-leetcode/tree/master/note\n[companies]: https://github.com/Blankj/awesome-java-leetcode/blob/master/Companies.md\n\n[0001]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0001/README.md\n[0007]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0007/README.md\n[0009]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0009/README.md\n[0013]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0013/README.md\n[0014]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0014/README.md\n[16_11]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/16_11/README.md\n[0020]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0020/README.md\n[0021]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0021/README.md\n[0026]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0026/README.md\n[0027]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0027/README.md\n[0028]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0028/README.md\n[0035]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0035/README.md\n[0038]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0038/README.md\n[0053]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0053/README.md\n[0058]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0058/README.md\n[0066]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0066/README.md\n[0067]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0067/README.md\n[0069]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0069/README.md\n[0070]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0070/README.md\n[0083]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0083/README.md\n[0088]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0088/README.md\n[0100]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0100/README.md\n[0101]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0101/README.md\n[0104]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0104/README.md\n[0107]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0107/README.md\n[0108]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0108/README.md\n[0110]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0110/README.md\n[0111]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0111/README.md\n[0112]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0112/README.md\n[0118]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0118/README.md\n[0119]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0119/README.md\n[0121]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0121/README.md\n[0122]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0122/README.md\n[0543]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0543/README.md\n\n[0002]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0002/README.md\n[0003]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0003/README.md\n[0005]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0005/README.md\n[0006]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0006/README.md\n[0008]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0008/README.md\n[0011]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0011/README.md\n[0012]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0012/README.md\n[0015]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0015/README.md\n[0016]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0016/README.md\n[0017]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0017/README.md\n[0018]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0018/README.md\n[0019]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0019/README.md\n[0022]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0022/README.md\n[0024]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0024/README.md\n[0029]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0029/README.md\n[0033]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0033/README.md\n[0043]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0043/README.md\n[0049]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0049/README.md\n[0050]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0050/README.md\n[0056]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0056/README.md\n[0063]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0063/README.md\n[0209]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0209/README.md\n[0215]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0215/README.md\n[0554]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0554/README.md\n[1014]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/1014/README.md\n\n[0004]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0004/README.md\n[0010]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0010/README.md\n[0023]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0023/README.md\n[0025]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0025/README.md\n[0030]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0030/README.md\n[0044]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0044/README.md\n[0057]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0057/README.md\n[0068]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/0068/README.md\n[1028]: https://github.com/Blankj/awesome-java-leetcode/blob/master/note/1028/README.md\n","funding_links":["https://raw.githubusercontent.com/Blankj/AndroidUtilCode/master/art/donate.png"],"categories":["Online Programming Learning Websites","算法","Java","Java/Kotlin","Github","算法题"],"sub_categories":["[leetcode](https://leetcode.com)","LeetCode"],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FBlankj%2Fawesome-java-leetcode","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FBlankj%2Fawesome-java-leetcode","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FBlankj%2Fawesome-java-leetcode/lists"}