代码随想录算法训练营第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

相关文章

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

MySQL实现多源复制的示例代码

《MySQL实现多源复制的示例代码》MySQL的多源复制允许一个从服务器从多个主服务器复制数据,这在需要将多个数据源汇聚到一个数据库实例时非常有用,下面就来详细的介绍一下,感兴趣的可以了解一下... 目录一、多源复制原理二、多源复制配置步骤2.1 主服务器配置Master1配置Master2配置2.2 从服

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据