合法括号字符串|递归|树

后续可刷 树上滑窗 树上差分

树的建模 天然log递归砍半处理

dfs抽象建图后 滑窗 差分 对于跑图时间复杂度的思考

lc761

特殊二进制串拼接最大字典序

++把字符串按合法1-0平衡段拆分,每段递归处理内部后降序排序再拼接++,就是最大字典序结果

class Solution {

public:

string makeLargestSpecial(string s) {

if (s.size() <= 2) {

return s;

}

// 把 s 划分成若干段合法括号字符串,记录在 substrings 中

vector<string> substrings;

int diff = 0; // 左括号个数 - 右括号个数

int start = 0; // 子串开始下标

for (int i = 0; i < s.size(); i++) {

if (s[i] == '1') { // 左括号

diff++;

} else if (--diff == 0) { // 右括号

// 子串 [start, i] 是合法括号字符串,且无法继续划分

// 这意味着子串 [start, i] 只能是嵌套的括号,那么去掉外层的括号,递归解决 [start+1, i-1]

substrings.push_back("1" + makeLargestSpecial(s.substr(start + 1, i - start - 1)) + "0");

start = i + 1; // 下一个子串从 i+1 开始

}

}

ranges::sort(substrings, greater());

auto joined = substrings | views::join;

return string(joined.begin(), joined.end());

}

};

相关推荐
cpp_250115 小时前
P1024 [NOIP 2001 提高组] 一元三次方程求解
数据结构·c++·算法·题解·二分答案·洛谷·csp
田梓燊1 天前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
re林檎1 天前
算法札记——4.27
算法
数据牧羊人的成长笔记1 天前
逻辑回归与Softmax回归
算法·回归·逻辑回归
郑州光合科技余经理1 天前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
d111111111d1 天前
STM32-UART封装问题解析
笔记·stm32·单片机·嵌入式硬件·学习·算法
Jiangxl~1 天前
IP数据云如何为不同行业提供精准IP查询与风险防控解决方案?
网络·网络协议·tcp/ip·算法·ai·ip·安全架构
李伟_Li慢慢1 天前
wolfram详解山峦算法
前端·算法
counting money1 天前
prim算法最小生成树(java)
算法
澈2071 天前
C++面向对象:类与对象核心解析
c++·算法