LeetCode刷题(一)

2020-05-05  本文已影响0人  didadu

面试题58 - II. 左旋转字符串

class Solution {
    public String reverseLeftWords(String s, int n) {
        String str = s.substring(0,n);
        String str2 = s.substring(n);
        return str2.concat(str);
    }
}

LCP 01.猜数字

class Solution {
        public int game(int[] guess, int[] answer) {
            int cnt=0;
            for(int i = 0;i<3;i++){
                if(guess[i] == answer[i]){
                    cnt++;
                }
            }
            return cnt;
        }
    }

1295. 统计位数为偶数的数字

class Solution {
    public int findNumbers(int[] nums) {
        int count = 0;
        for(int num:nums){
            String numStr = String.valueOf(num);
            int len = numStr.length();
            if(len%2 == 0) count++;
        }
        return count;
    }
}

21. 合并两个有序链表

class Solution {
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        if(l1 == null) return l2;
        else if(l2 == null) return l1;
        else{
            if(l1.val < l2.val){
                l1.next = mergeTwoLists(l1.next,l2);
                return l1;
            }else{
                l2.next = mergeTwoLists(l1, l2.next);
                return l2;
            }
        }
    }
}

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

class Solution {
    public int lengthOfLongestSubstring(String s) {
        int n = s.length(), ans = 0;
        Map<Character, Integer> map = new HashMap<>();
        for (int end = 0, start = 0; end < n; end++) {
            char alpha = s.charAt(end);
            if (map.containsKey(alpha)) {
                start = Math.max(map.get(alpha), start);
            }
            ans = Math.max(ans, end - start + 1);
            map.put(s.charAt(end), end + 1);
        }
        return ans;
    }
}

45. 跳跃游戏 II

class Solution {
    public int jump(int[] nums) {
        int end = 0;
        int maxPosition = 0; 
        int steps = 0;
        for(int i = 0; i < nums.length - 1; i++){
            maxPosition = Math.max(maxPosition, nums[i] + i); 
            if( i == end){ 
                end = maxPosition;
                steps++;
            }
        }
    return steps;
    }
}

98. 验证二叉搜索树

假设一个二叉搜索树具有如下特征:

节点的左子树只包含小于当前节点的数。
节点的右子树只包含大于当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。

class Solution {
     public boolean isValidBST(TreeNode root) {
        return dfs(root, Long.MIN_VALUE, Long.MAX_VALUE);
    }
    boolean dfs(TreeNode node, long lower, long upper) {
        if (node == null)  return true;
        if (node.val <= lower) return false;
        if (node.val >= upper) return false;
        if (!dfs(node.left, lower, node.val)) return false;
        if (!dfs(node.right, node.val, upper)) return false;
        return true;
    }
}
上一篇 下一篇

猜你喜欢

热点阅读