文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

LeetCode经典算法题解,Java实现版!

2023-09-01 08:42

关注

在程序员的职业生涯中,算法是一个非常重要的领域。而LeetCode作为一个非常流行的在线编程平台,它提供了大量的算法题目,帮助程序员们提高算法能力。在这篇文章中,我们将为你介绍一些经典的算法题目,并提供Java实现版的解题思路和代码。

1.两数之和

题目描述:给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。

示例:

输入:nums = [2, 7, 11, 15], target = 9

输出:[0, 1]

解释:nums[0] + nums[1] = 2 + 7 = 9,返回[0, 1]

解题思路:使用哈希表(HashMap)来存储数组中的元素和它们对应的下标。遍历数组,对于每一个元素,在哈希表中查找是否存在与之匹配的值,如果存在则返回它们的下标。

Java代码:

class Solution { public int[] twoSum(int[] nums, int target) { Map<Integer, Integer> map = new HashMap<>(); for (int i = 0; i < nums.length; i++) { int complement = target - nums[i]; if (map.containsKey(complement)) { return new int[] { map.get(complement), i }; } map.put(nums[i], i); } throw new IllegalArgumentException("No two sum solution"); } }

2.两数相加

题目描述:给定两个非空链表,表示两个非负整数。它们每位数字都是按照逆序方式存储的,并且每个节点只能存储一位数字。将这两个数相加起来,返回一个新的链表。

示例:

输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)

输出:7 -> 0 -> 8

解释:342 + 465 = 807,返回链表:7 -> 0 -> 8

解题思路:模拟两数相加的过程,从链表的头开始依次相加对应节点的值,如果有进位则在下一位相加时加上进位。需要注意的是,如果两个链表的长度不同,则可以将短链表的空位补零。

Java代码:

class Solution { public ListNode addTwoNumbers(ListNode l1, ListNode l2) { ListNode dummyHead = new ListNode(0); ListNode p = l1, q = l2, curr = dummyHead; int carry = 0; while (p != null || q != null) { int x = (p != null) ? p.val : 0; int y = (q != null) ? q.val : 0; int sum = carry + x + y; carry = sum / 10; curr.next = new ListNode(sum % 10); curr = curr.next; if (p != null) p = p.next; if (q != null) q = q.next; } if (carry > 0) { curr.next = new ListNode(carry); } return dummyHead.next; } }

3.无重复字符的最长子串

题目描述:给定一个字符串,请你找出其中不含有重复字符的最长子串的长度。

示例:

输入:"abcabcbb"

输出:3

解释:因为无重复字符的最长子串是 "abc",所以其长度为 3。

解题思路:使用滑动窗口(双指针)来遍历字符串,用一个HashSet来存储窗口内的字符,如果遇到重复的字符则移动左指针,直到窗口内不再有重复字符。

Java代码:

class Solution { public int lengthOfLongestSubstring(String s) { int n = s.length(), ans = 0; Set set = new HashSet<>(); int i = 0, j = 0; while (i < n && j < n) { if (!set.contains(s.charAt(j))) { set.add(s.charAt(j++)); ans = Math.max(ans, j - i); } else { set.remove(s.charAt(i++)); } } return ans; } }

总结

LeetCode是一个非常好的平台,它提供了大量的算法题目,帮助程序员们提高算法能力。这篇文章介绍了三个经典的算法题目,并提供Java实现版的解题思路和代码。希望这篇文章对你有所帮助。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯