Leetcode (力扣)做题记录 hot100(62,64,287,108)

力扣第62题:不同路径

62. 不同路径 - 力扣(LeetCode)

java 复制代码
class Solution {
    public int uniquePaths(int m, int n) {
        int[][] array = new int[m][n];
        for(int i = 0;i<n;i++){
            array[0][i] = 1;
        }
        for(int i = 0;i<m;i++){
            array[i][0] = 1;
        }
        for(int i = 1;i<m;i++){
            for(int j =1;j<n;j++ ){
                array[i][j] = array[i - 1][j] + array[i] [j-1];
            }
        }
        return array[m -1] [ n - 1];
    }
    
}
力扣第64题:最小路径和

64. 最小路径和 - 力扣(LeetCode)

java 复制代码
class Solution {
    public int minPathSum(int[][] grid) {
        int[][] array= new int[grid.length][grid[0].length];
        array[0][0] = grid[0][0];
        //行
        for(int i = 1;i<grid[0].length;i++){
            array[0][i] = array[0][i -1] + grid[0][i];
        }
        //列
        for(int i = 1;i<grid.length;i++){
            array[i][0] = array[i - 1][0] + grid[i][0];
        }
        for(int i = 1;i<grid.length;i++){
            for(int j = 1;j<grid[0].length;j++){
                array[i][j] = Math.min(array[i - 1][j] ,array[i][j - 1]) + grid[i][j];
            }
        }
        return array[grid.length - 1][grid[0].length - 1];
    }
}
力扣第287题:寻找重复数

287. 寻找重复数 - 力扣(LeetCode)

java 复制代码
class Solution {
    public int findDuplicate(int[] nums) {
        HashMap<Integer,Integer> map = new HashMap<>();
        for(int num: nums){
            if(map.containsKey(num)){
                return num;
            }
            map.put(num,1);
        }
        return - 1;
    }
}
复制代码
力扣第108题:将有序数组转换为二叉搜索树

108. 将有序数组转换为二叉搜索树 - 力扣(LeetCode)

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public TreeNode sortedArrayToBST(int[] nums) {
       return helper(nums,0,nums.length - 1);
    }
    private TreeNode helper(int nums[],int left,int right){
        if(left > right){
            return null;
        }
        int mid = (left + right) /2;
        TreeNode s = new TreeNode(nums[mid]);
        s.left = helper(nums,left,mid-1);
        s.right = helper(nums,mid + 1,right);
            return s;
    }
}
复制代码

本文相关图片资源来自于网络中,如有侵权请联系删除!

相关推荐
仙俊红43 分钟前
LeetCode487周赛T2,删除子数组后的最终元素
数据结构·算法
-dzk-7 小时前
【代码随想录】LC 59.螺旋矩阵 II
c++·线性代数·算法·矩阵·模拟
风筝在晴天搁浅7 小时前
hot100 78.子集
java·算法
Jasmine_llq7 小时前
《P4587 [FJOI2016] 神秘数》
算法·倍增思想·稀疏表(st 表)·前缀和数组(解决静态区间和查询·st表核心实现高效预处理和查询·预处理优化(提前计算所需信息·快速io提升大规模数据读写效率
超级大只老咪7 小时前
快速进制转换
笔记·算法
m0_706653238 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你918 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
qq_423233908 小时前
C++与Python混合编程实战
开发语言·c++·算法
TracyCoder1238 小时前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
m0_715575348 小时前
分布式任务调度系统
开发语言·c++·算法