代码随想录算法训练营第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调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT