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

2024-05-25 16:52

本文主要是介绍代码随想录算法训练营第36期DAY39,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

DAY39

738单调递增的数字

  1. 暴力法:

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

  1. class Solution {
  2. private:
  3.     bool checknum(int num){
  4.         if(num<10return 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==0return "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==nullptrreturn 2;
  18.         int l=getres(root->left);
  19.         int r=getres(root->right);
  20.         if(l==2&&r==2return 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. };

这篇关于代码随想录算法训练营第36期DAY39的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1002085

相关文章

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

MyBatis中的两种参数传递类型详解(示例代码)

《MyBatis中的两种参数传递类型详解(示例代码)》文章介绍了MyBatis中传递多个参数的两种方式,使用Map和使用@Param注解或封装POJO,Map方式适用于动态、不固定的参数,但可读性和安... 目录✅ android方式一:使用Map<String, Object>✅ 方式二:使用@Param

SpringBoot实现图形验证码的示例代码

《SpringBoot实现图形验证码的示例代码》验证码的实现方式有很多,可以由前端实现,也可以由后端进行实现,也有很多的插件和工具包可以使用,在这里,我们使用Hutool提供的小工具实现,本文介绍Sp... 目录项目创建前端代码实现约定前后端交互接口需求分析接口定义Hutool工具实现服务器端代码引入依赖获

利用Python在万圣节实现比心弹窗告白代码

《利用Python在万圣节实现比心弹窗告白代码》:本文主要介绍关于利用Python在万圣节实现比心弹窗告白代码的相关资料,每个弹窗会显示一条温馨提示,程序通过参数方程绘制爱心形状,并使用多线程技术... 目录前言效果预览要点1. 爱心曲线方程2. 显示温馨弹窗函数(详细拆解)2.1 函数定义和延迟机制2.2

Springmvc常用的注解代码示例

《Springmvc常用的注解代码示例》本文介绍了SpringMVC中常用的控制器和请求映射注解,包括@Controller、@RequestMapping等,以及请求参数绑定注解,如@Request... 目录一、控制器与请求映射注解二、请求参数绑定注解三、其他常用注解(扩展)四、注解使用注意事项一、控制

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

VS Code中的Python代码格式化插件示例讲解

《VSCode中的Python代码格式化插件示例讲解》在Java开发过程中,代码的规范性和可读性至关重要,一个团队中如果每个开发者的代码风格各异,会给代码的维护、审查和协作带来极大的困难,这篇文章主... 目录前言如何安装与配置使用建议与技巧如何选择总结前言在 VS Code 中,有几款非常出色的 pyt

利用Python将PDF文件转换为PNG图片的代码示例

《利用Python将PDF文件转换为PNG图片的代码示例》在日常工作和开发中,我们经常需要处理各种文档格式,PDF作为一种通用且跨平台的文档格式,被广泛应用于合同、报告、电子书等场景,然而,有时我们需... 目录引言为什么选择 python 进行 PDF 转 PNG?Spire.PDF for Python

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)