当前位置: 首页 > article >正文

Leetcode.1849 将字符串拆分为递减的连续值

题目链接

Leetcode.1849 将字符串拆分为递减的连续值 Rating : 1747

题目描述

给你一个仅由数字组成的字符串 s

请你判断能否将 s拆分成 两个或者多个 非空子字符串 ,使子字符串的 数值降序 排列,且每两个 相邻子字符串 的数值之 等于 1

  • 例如,字符串 s = "0090089"可以拆分成 ["0090", "089"],数值为 [90,89]。这些数值满足按降序排列,且相邻值相差 1 ,这种拆分方法可行。
  • 另一个例子中,字符串 s = "001"可以拆分成 ["0", "01"]["00", "1"]["0", "0", "1"]。然而,所有这些拆分方法都不可行,因为对应数值分别是 [0,1]、[0,1][0,0,1],都不满足按降序排列的要求。

如果可以按要求拆分 s,返回 true ;否则,返回 false

子字符串 是字符串中的一个连续字符序列。

示例 1:

输入:s = “1234”
输出:false
解释:不存在拆分 s 的可行方法。

示例 2:

输入:s = “050043”
输出:true
解释:s 可以拆分为 [“05”, “004”, “3”] ,对应数值为 [5,4,3] 。
满足按降序排列,且相邻值相差 1 。

示例 3:

输入:s = “9080701”
输出:false
解释:不存在拆分 s 的可行方法。

示例 4:

输入:s = “10009998”
输出:true
解释:s 可以拆分为 [“100”, “099”, “98”] ,对应数值为 [100,99,98] 。
满足按降序排列,且相邻值相差 1 。

提示:

  • 1 < = s . l e n g t h < = 20 1 <= s.length <= 20 1<=s.length<=20
  • s仅由数字组成

解法:模拟

提示1:题目要求相邻字符串数值之差为1,说明当确定第一个字符串时,后续字符串的数值也就确定了。

提示2:题目要求最少分成两个串,s.size()最大才是 20,一个子串的值不能超过 1 0 10 10^{10} 1010,超过就无解了。

pre表示第一段子串的值,用 cur表示接下来每一段子串 实际的值,用 next表示接下来每一段子串 正确的值

时间复杂度: O ( n 2 ) O(n^2) O(n2)

C++代码:

using LL = long long;
class Solution {
public:
    bool splitString(string s) {
        int n = s.size();
        //第一段子串的值 和 子串最大的值
        LL pre = 0,mx = 1e10;

        for(int i = 0;i < n;i++){
            pre = pre * 10 + (s[i] - '0');
            //如果有子串的值 > mx 后面也不会有解了
            if(pre > mx) break;

            //cur 表示接下来每一段 实际的值
            //next 表示接下来每一段 符合条件的值
            LL cur = 0;
            LL next = pre - 1;
            
            for(int j = i + 1;j < n && next >= 0;j++){
                cur = cur * 10 + (s[j] - '0');
                //这一段子串的值符合要求,更新 next 和 cur 开始寻找下一段
                //只有当 cur 的这一段是最后一段时,并且 cur == next , cur 才允许为0 if((cur == next && cur != 0) || (cur == next && cur == 0 && j == n - 1)){
                    cur = 0;
                    next--;
                    //当前已经是最后一段,说明s 可以分解为题目要求的非空子串,直接返回 true
                    if(j == n - 1) return true;
                }
                //cur > next 说明该段不符合要求,直接退出循环
                else if(cur > next) break;
            }
        }

        return false;
    }
};


http://www.kler.cn/a/5475.html

相关文章:

  • 自动化测试-Pytest测试
  • Zabbix企业级分布式监控系统
  • python版本的Selenium的下载及chrome环境搭建和简单使用
  • 【JS】期约的Promise.all()和 Promise.race()区别
  • (一)开发环境搭建以及配置
  • 如何利用云计算进行灾难恢复?
  • 第二十八章 变换坐标总结
  • C++模板基础(四)
  • 有了Bug,先看看类型
  • Activation Function激活函数
  • 三极管用作开关电路的一些思考
  • 跟着AI学AI(1): 线性回归模型
  • 如何使用Spring+OpenAI生成图像
  • 多传感器融合定位GNSS、IMU、Lidar、Camera
  • 06 Laplacian算法
  • HTML5 SSE
  • 数据结构和算法(3):递归
  • 程序员万万不能去的3种公司,越做越倒退,过来人的经验
  • VerilogHDL基本语法和程序
  • PCB模块化设计24——DCDC电源模块PCB布局布线设计规范
  • python Format()函数的用法___实例详解(一)(全,例多)___各种格式化替换,format对齐打印
  • WTI原油交易价格(1986年1⽉2⽇-2022年9⽉6⽇)
  • (数字图像处理MATLAB+Python)第三章图像基本运算-第一节:图像几何变换
  • 卷麻了,00后测试用例写的比我还好,简直无地自容.....
  • ChatGPT +工业机器人/自动驾驶控制器的一些尝试
  • 【bugdebug】为什么表名没有输入错误,数据库连接也连上了,但一查询还是显示对象名“XXX”无效?