三道简单算法题——java 解答

63 篇文章 4 订阅
54 篇文章 0 订阅

三个谷歌算法题的Java解答,并配以图解说明。

1. 反转链表

题目描述:

给定一个单链表的头节点 head,编写一个函数来反转链表,并返回新的头节点。

Java 解答:
public ListNode reverseList(ListNode head) {
    ListNode prev = null;
    ListNode curr = head;
    while (curr != null) {
        ListNode nextTemp = curr.next;
        curr.next = prev;
        prev = curr;
        curr = nextTemp;
    }
    return prev;
}
图解:
  1. 初始化两个指针:prev(初始为 null)和 curr(指向头节点 head)。
  2. 遍历链表,每次迭代中,将 currnext 指针指向 prev
  3. 更新 prevcurr,直到 currnull
  4. 返回新的头节点,即 prev

2. 二叉树的最大深度

题目描述:

给定一个二叉树,找出其最大深度。

Java 解答:
public int maxDepth(TreeNode root) {
    if (root == null) {
        return 0;
    } else {
        int leftDepth = maxDepth(root.left);
        int rightDepth = maxDepth(root.right);
        return Math.max(leftDepth, rightDepth) + 1;
    }
}
图解:
  1. 如果根节点为 null,返回深度 0
  2. 递归计算左子树和右子树的最大深度。
  3. 返回左右子树深度的最大值加 1(当前节点的深度)。

3. 有效的括号

题目描述:

给定一个只包括 '('')''{''}''['']' 的字符串,判断字符串是否有效。

Java 解答:
public boolean isValid(String s) {
    Stack<Character> stack = new Stack<>();
    for (char c : s.toCharArray()) {
        if (c == '(' || c == '[' || c == '{') {
            stack.push(c);
        } else {
            if (stack.isEmpty()) return false;
            char top = stack.pop();
            if ((c == ')' && top != '(') || (c == ']' && top != '[') || (c == '}' && top != '{')) {
                return false;
            }
        }
    }
    return stack.isEmpty();
}
图解:
  1. 使用栈来存储开括号。
  2. 遍历字符串中的每个字符:
    • 如果是开括号,压入栈中。
    • 如果是闭括号,检查栈顶元素是否与之匹配。如果不匹配或栈为空,则返回 false
  3. 遍历完成后,如果栈为空,则字符串有效,否则无效。

在这里插入图片描述

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值