代码随想录刷题|LeetCode 738.单调递增的数字 714. 买卖股票的最佳时机含手续费 968.监控二叉树

简介: 代码随想录刷题|LeetCode 738.单调递增的数字 714. 买卖股票的最佳时机含手续费 968.监控二叉树

738.单调递增的数字

题目链接:力扣

思路


   这个题意是很简单的,拿到题目就会有一个思路,就是沿着给定的数字往下判断就可以了,这其实是一种暴力解法,对java语言来说会超出时长。所以应该使用其他方法


       本题要求的是小于等于N的最大单调递增的正数,要明白一种情况:一旦出现strNum[i - 1] > strNum[i]的情况(非单调递增),首先想让strNum[i - 1]--,然后strNum[i]给为9

       比如:332 ,后面的32是不满足的,那就将2变成9,前面的3减一变成2。

                 成为了329,其实中间的331,330,也都是不满足的

                 此时前面的32也是不满足的,那就将2变成9,前面的3减一变成2.

                 成为了229,其中230-329 都是不满足的


       所以这道题目的局部最优是:遇到strNum[i - 1] > strNum[i]的情况,让strNum[i - 1]--,然后strNum[i]给为9,可以保证这两位变成最大单调递增整数


       全局最优是:得到小于等于N的最大单调递增的整数


       可以从局部最优可以推出全局最优,但是还存在一个问题,那就是对数字的遍历顺序,是从前向后遍历呢,还是从后向前遍历呢


       还是以332为例:

       从前向后遍历,33 是满足条件的,32是不满足条件的,改成29,最终是329,是不可以的,所以从前向后遍历会改变已经遍历过的结果了,就会造成不准确

       从后向前遍历,32是不满足情况的,改成29,为329,接下来,32是不满足情况的,改成29,最终是229,所以从后向前遍历,是可以不断利用上次比较出的结果的


       所以这道题目要想清楚两件事:

               1、贪心思路在哪里:怎么保证局部最优,这个是不好想到的

               2、选择哪种遍历顺序


单调递增的数字

暴力解法(会超出时长)

class Solution {
    public int monotoneIncreasingDigits(int n) {
        for (int i = n; i > 0; i--) {
            if (checkNum(i)) {
                return i;
            }           
        }
        return 0;
    }
    private boolean checkNum(int num) {
        int max = 10;
        while (num > 0) {
            int t = num % 10;
            if (max >= t) {
                max = t;
            } else {
                return false;
            }
            num = num / 10;
        }
        return true;
    }
}

贪心解法

       java中

class Solution {
    public int monotoneIncreasingDigits(int n) {
        // 将数组转换成字符串
        String s = String.valueOf(n);
        // 将字符串转换成字符数组
        char[] chars = s.toCharArray();
        int start = s.length();
        for (int i = s.length() - 2; i >= 0; i--) {
            if (chars[i] > chars[i + 1]) {
                chars[i]--;
                start = i + 1;
            }
        }
        for (int i = start; i < s.length(); i++) {
            chars[i] = '9';
        }
        return Integer.parseInt(String.valueOf(chars));
    }
}

714. 买卖股票的最佳时机含手续费

题目链接:力扣

思路

       二刷再看

买卖股票的最佳时机含手续费

968.监控二叉树

题目链接:力扣

思路

       二刷再看

监控二叉树

相关文章
|
4天前
|
算法 索引
leetcode代码记录(买卖股票的最佳时机
leetcode代码记录(买卖股票的最佳时机
9 1
|
4天前
|
算法
leetcode代码记录(买卖股票的最佳时机 IV
leetcode代码记录(买卖股票的最佳时机 IV
9 2
|
4天前
|
算法
leetcode代码记录(买卖股票的最佳时机 III
leetcode代码记录(买卖股票的最佳时机 III
12 5
|
4天前
leetcode代码记录(买卖股票的最佳时机 II
leetcode代码记录(买卖股票的最佳时机 II
8 1
|
4天前
|
算法 C++
【刷题】Leetcode 1609.奇偶树
这道题是我目前做过最难的题,虽然没有一遍做出来,但是参考大佬的代码,慢慢啃的感觉的真的很好。刷题继续!!!!!!
8 0
|
4天前
|
算法 索引
【刷题】滑动窗口精通 — Leetcode 30. 串联所有单词的子串 | Leetcode 76. 最小覆盖子串
经过这两道题目的书写,相信大家一定深刻认识到了滑动窗口的使用方法!!! 下面请大家继续刷题吧!!!
9 0
|
4天前
|
算法
【刷题】 leetcode 面试题 08.05.递归乘法
递归算法是一种在计算机科学和数学中广泛应用的解决问题的方法,其基本思想是利用问题的自我相似性,即将一个大问题分解为一个或多个相同或相似的小问题来解决。递归算法的核心在于函数(或过程)能够直接或间接地调用自身来求解问题的不同部分,直到达到基本情况(也称为基础案例或终止条件),这时可以直接得出答案而不必再进行递归调用。
21 4
【刷题】 leetcode 面试题 08.05.递归乘法
|
4天前
|
存储 算法 安全
【刷题】 leetcode 面试题 01.06 字符串压缩
来看效果: 非常好!!!过啦!!!
25 5
【刷题】 leetcode 面试题 01.06 字符串压缩
|
4天前
|
存储 算法 测试技术