首页 > 编程语言 >代码随想录算法训练营第36期DAY39

代码随想录算法训练营第36期DAY39

时间:2024-05-25 16:01:52浏览次数:28  
标签:return DAY39 int 随想录 36 num result str TreeNode

道心破碎的一天,继续加油吧,坚持努力。

DAY39

738单调递增的数字

  1. 暴力法:

没有想到用int i=n;i>0;i--来遍历。

  1. class Solution {
  2. private:
  3.     bool checknum(int num){
  4.         if(num<10) return true;
  5.         while(num/10!=0){
  6.             int low=num%10;
  7.             num/=10;
  8.             if(num%10>low) return false;
  9.         }
  10.         return true;
  11.     }
  12. public:
  13.     //先试试暴力法。
  14.     int monotoneIncreasingDigits(int n) {
  15.         for(int i=n;i>0;i--){
  16.             if(checknum(i)) return i;
  17.         }
  18.         return 0;
  19.     }
  20. };

  1. 力扣优质题解--Sweetiee

自己写了一遍,写不出来。。。

整理一下题解的思路:

既然要尽可能的大,那么这个数从高位开始要尽可能地保持不变。我们要找到从高到低第一个满足str[i]>str[i+1]的位置,然后把str[i]-1,再把后面的位置都变成9即可。

但是由于减小了str[i]之后,可能不满足str[i-1]<=str[i]了,若发生了这种情况,一定是str[i-1]==str[i],此时就需要再str[i-1]-1,递归地会处理到某个位置idx,我们发现:str[idx]==str[idx+1]==...==str[i]。然后只要str[idx]-1,然后后面都补上9即可。

所以:遍历时候,求当前最大数字max,只在max<arr[i]的时候才更新max对应的idx(类似于:查找数组中最大的元素,返回最小的下标)。**接着判断是否有arr[i]>arr[i+1]**,如果是,那么idx位置数字减1,后面位置全部为9即可。

很多细节。也算是锻炼到了。加油。

  1. class Solution {
  2. public:
  3.     int monotoneIncreasingDigits(int n) {
  4.         int max=-1,idx=-1;
  5.         auto s=to_string(n);
  6.         //注意不要越界
  7.         for(int i=0;i<s.size()-1;i++){
  8.             if(max<s[i]){
  9.                 max=s[i];
  10.                 idx=i;
  11.             }
  12.             if(s[i]>s[i+1]){
  13.                 s[idx]-=1;
  14.                 for(int j=idx+1;j<s.size();j++) s[j]='9';
  15.                 break;
  16.             }
  17.         }
  18.         return stoi(s);
  19.     }
  20. };

  1. 代码随想录官方题解

这个贪心就稍微好想到,也容易理解和实现了:

思路:遇到非递增,就让大数减1,声明变量记录需要置为9的位置。为了利用局部信息,需要从后向前遍历。

  1. class Solution {
  2. public:
  3.     int monotoneIncreasingDigits(int n) {
  4.         auto s=to_string(n);
  5.         int flag=s.size();
  6.         for(int i=s.size()-1;i>0;i--){
  7.             if(s[i-1]>s[i]){
  8.                 flag=i;
  9.                 s[i-1]--;
  10.             }
  11.         }
  12.         for(int i=flag;i<s.size();i++){
  13.             s[i]='9';
  14.         }
  15.         return stoi(s);
  16.     }
  17. };

除此之外,你还需要掌握函数名及手写它们:

  1. to_string()

  1. std::string my_to_string(int num){
  2.     bool isNegative=false;
  3.     std::string str;
  4.     if(num==0) return "0";
  5.     if(num<0){
  6.         isNegative=true;
  7.         num*=-1;
  8.     }
  9.     while(num>0){
  10.         //不知道+'0'和减'0'有什么区别,还是写+吧。
  11.         str+=(num%10)+'0';
  12.         num/=10;
  13.     }
  14.     if(isNegative) str+='-';
  15.     reverse(str.begin(),str.end());
  16.     return str;
  17. }

  1. stroi()

  1. int my_stoi(std::string str){
  2.     int result=0;
  3.     bool isNegative=false;
  4.     int i=0;
  5.     if(str[0]=='-'){
  6.         isNegative=true;
  7.         i=1;
  8.     }
  9.     for(;i<str.size();i++){
  10.         if(str[i]<'0'||str[i]>'9'){
  11.             throw std::invalid_argument("Invalid input string");
  12.         }
  13.         //记住这句模版
  14.         result=result*10+(str[i]-'0');
  15.     }
  16.     if(isNegative) result*=-1;
  17.     return result;
  18. }

  1. stol

968监控二叉树,困难

看代码随想录题解过的:

  1. /**
  2.  * Definition for a binary tree node.
  3.  * struct TreeNode {
  4.  *     int val;
  5.  *     TreeNode *left;
  6.  *     TreeNode *right;
  7.  *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
  8.  *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
  9.  *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
  10.  * };
  11.  */
  12. class Solution {
  13. public:
  14.     int result=0;
  15.     int getres(TreeNode* root){
  16.         //递归终止逻辑
  17.         if(root==nullptr) return 2;
  18.         int l=getres(root->left);
  19.         int r=getres(root->right);
  20.         if(l==2&&r==2) return 0;
  21.         if(l==0||r==0){
  22.             result++;
  23.             return 1;
  24.         }
  25.         if(l==1||r==1){
  26.             return 2;
  27.         }
  28.         return -1;
  29.     }
  30.     int minCameraCover(TreeNode* root) {
  31.         if(getres(root)==0) result++;
  32.         return result;
  33.     }
  34. };

标签:return,DAY39,int,随想录,36,num,result,str,TreeNode
From: https://blog.csdn.net/illuosion7/article/details/139198901

相关文章

  • 代码随想录算法训练营第36期DAY37
    DAY37先二刷昨天的3道题目,每种方法都写:是否已完成:是。报告:134加油站的朴素法没写对。原因是:在if中缺少了store>=0的判断,只给出了index==i的判断。前进法没写出来。因为忘记了总油量的判断。Sum。注意变量的初始化。分配糖果注意if里面放的是ratings;860柠檬水找零网上摘得思......
  • 代码随想录——二叉树的所有路径(Leetcode257)需要回顾
    题目链接BFS+队列维护一个队列,存储节点以及根到该节点的路径。一开始这个队列里只有根节点。在每一步迭代中,我们取出队列中的首节点,如果它是叶子节点,则将它对应的路径加入到答案中。如果它不是叶子节点,则将它的所有孩子节点加入到队列的末尾。当队列为空时广度优先搜......
  • 代码随想录算法训练营第一天 | 977.有序数组的平方;
    代码随想录算法训练营第一天|977.有序数组的平方;977题链接:https://leetcode.cn/problems/squares-of-a-sorted-array/代码随想录链接:https://programmercarl.com/0977.有序数组的平方.html#思路209题链接:https://leetcode.cn/problems/minimum-size-subarray-sum/submission......
  • 代码随想录算法训练营第第17天 | 110.平衡二叉树、257. 二叉树的所有路径、404.左叶子
    三道题都没想出来,还是要加强递归的练习110.平衡二叉树(优先掌握递归)再一次涉及到,什么是高度,什么是深度,可以巩固一下。题目链接/文章讲解/视频讲解:https://programmercarl.com/0110.平衡二叉树.htmlfunctiongetHeight(node){if(node===null)return0;letleftH......
  • 新定义RD8T36P48使用USCI0的TWI功能点亮OLED
    时间不多,因此先只给出工程,等有时间再添加详细说明现象这是从之前的一个51单片机的程序移植过来的,主要修改了IIC启动和停止,以及数据发送的代码,我现在还不是很满意的一点是发送过程中要等待上一个字节发送完才能接着发送本次字节。我使用的是while循环等待发送完成标志位,......
  • 新定义RD8T36P48点亮LED--汇编
    其实汇编和C语言差不多,简单的东西用汇编挺好,中等及以上复杂度的程序还是C语言更灵活直接在keil新建好工程,选好芯片型号和下载方式,再创建一个.asm文件并添加到工程,工程创建完如图工程配置代码 ORG0000H LJMPMAIN ORG0100HMAIN: MOVA,9AH ORLA,#20H;让P05为......
  • 算法随想录打卡第三天|链表
    //203移除链表元素publicListNoderemoveElements(ListNodehead,intval){//创建虚拟头指针不对//ListNoderes=head;//创建一个虚拟头结点ListNoderes=newListNode(val-1);res.next=head;ListNodeprev=res;......
  • 代码随想录算法训练营第一天 | 704.二分查找;27. 移除元素
    代码随想录算法训练营第一天|704.二分查找(红蓝模板法);27.移除元素(双指针法)704题链接:https://leetcode.cn/problems/binary-search/description/二分查找:https://programmercarl.com/0704.二分查找.html#其他语言版本二分查找红蓝法笔记:二分查找为什么总是写错?_哔哩哔哩_bil......
  • 代码随想录算法训练营第十五天 | 层序遍历 、226.翻转二叉树、101.对称二叉树
    层序遍历题目链接:学会二叉树的层序遍历,可以一口气打完以下十题:102.二叉树的层序遍历107.二叉树的层次遍历II199.二叉树的右视图637.二叉树的层平均值429.N叉树的层序遍历515.在每个树行中找最大值116.填充每个节点的下一个右侧节点指针117.填充每个节点的下一个右侧节点......
  • 代码随想录算法训练营第三十六天|860.柠檬水找零、406.根据身高重建队列、452. 用最少
    860.柠檬水找零文档讲解:代码随想录题目链接:.-力扣(LeetCode)注意看提示:bills[i] 不是 5 就是 10 或是 20 场景较为固定遇到了20,优先消耗10classSolution:deflemonadeChange(self,bills:List[int])->bool:total={5:0,10:0,20:0}......