今日LeetCode 摸鱼打卡

x的平方根

这道很简单,但是直接暴力会超时,所以可用使用二分查找来快速秒掉

然后要注意的就是,判断大小的时候不要使用mid*mid == target,因为会溢出,直接使用mid == x / mid替代

具体代码:

java 复制代码
class Solution {
    public int mySqrt(int x) {
        if (x == 0) return 0;
        int l = 1;
        int r = Integer.MAX_VALUE;
        while (l <= r) {
            int mid = l + ((r - l) >> 1);
            if (mid == x / mid) return mid;
            if (mid > x / mid) r = mid - 1;
            if (mid < x / mid) l = mid + 1;
        }
        return l - 1;
    }
}

用栈实现队列

这道也是比较简单,直接两个栈模拟就行了

具体做法就是每次需要取队头元素的时候就直接将元素倒到另一个栈中,操作完再倒回来

具体代码:

java 复制代码
class MyQueue {

    Stack<Integer> sta1 = new Stack();
    Stack<Integer> sta2 = new Stack();

    public MyQueue() {}
    
    public void push(int x) {
        sta1.push(x);
    }
    
    public int pop() {
        return helper(2);
    }
    
    public int peek() {
        return helper(1);
    }
    
    public boolean empty() {
        return sta1.isEmpty();
    }

    // pop-2 peek-1  
    private int helper(int flag) {
        while (sta1.size() > 1) {
            sta2.push(sta1.pop());
        }
        int res = sta1.peek();
        if (flag == 2) sta1.pop();
        while (!sta2.isEmpty()) {
            sta1.push(sta2.pop());
        }
        return res;
    }
}

字符串相乘

这道也是比较简单,主要可以通过规律来找到

可以发现就是将num1i * numsj 的乘积累加到 ansi+j 位置就行了

具体代码:

java 复制代码
class Solution {
    public String multiply(String num1, String num2) {
        if (num1.equals("0") || num2.equals("0")) return "0";
        int n = num1.length();
        int m = num2.length();
        int[] ans = new int[n + m];
        for (int i = 0; i < n; i ++) {
            int a = num1.charAt(n-i-1) - '0';
            for (int j = 0; j < m; j ++) {
                int b = num2.charAt(m-j-1) - '0';
                ans[i+j] += a * b;
            }
        }

        int carry = 0;
        for (int i = 0; i < n + m; i ++) {
            int sum = ans[i] + carry;
            ans[i] = sum % 10;
            carry = sum / 10;
        }

        StringBuilder sb = new StringBuilder();
        for (int i = n+m-1; i >= 0; i --) {
            if (sb.isEmpty() && ans[i] == 0) continue;
            sb.append(ans[i]);
        }
        return sb.toString();
    }
}
相关推荐
云烟成雨TD7 小时前
Agent Scope Java 2.x 系列【11】中间件(Middleware):核心设计
java·人工智能·agent
心之伊始7 小时前
Spring AI Chat Memory 实战:用 JDBC 给 Java Agent 加会话记忆
java·spring boot·agent·spring ai·chat memory
凡人叶枫7 小时前
Effective C++ 条款40:明智而审慎地使用多重继承
java·数据库·c++·嵌入式开发·effective c++
放弃 治疗7 小时前
宝塔面板安装 JDK 完整教程|Java 环境配置详解
java·开发语言
仍然.8 小时前
算法题目---BFS解决最短路问题
算法·宽度优先
渡众机器人8 小时前
第八届全球校园人工智能算法精英大赛-算法应用赛-空地协同侦排挑战赛规则
人工智能·算法
至此流年莫相忘8 小时前
Spring 依赖注入三剑客:@Autowired、@Resource 与 @RequiredArgsConstructor 深度对比与实战指南
java·数据库·spring
wayz118 小时前
Overlap:HWMA(Holt-Winter移动平均线)技术指标详解
算法·金融·数据分析·量化交易·特征工程
零陵上将军_xdr8 小时前
为什么DCL单例要加volatile?——CPU乱序执行与内存屏障
java·linux
Shadow(⊙o⊙)8 小时前
专题四:前缀和
数据结构·算法