leetcode 763 未来跳跃游戏

这个题目挺抽象的,翻译成人话:

把字符串切成尽可能多的片段,满足一条铁律:

铁律(必须严格满足):同一个字母,只能出现在同一个片段里,绝对不能跨片段。

这个题目,我们先记录一下每个字母能到的最远位置,然后遍历,记录我们必须到达的最远位置,到了后就停。和跳跃游戏不同的是,由于我们已经能预知未来,所以直接和his_mx比就行,有所不同,多做多t体会~

cpp 复制代码
class Solution {
public:
    vector<int> partitionLabels(string s) {
        int n = s.size();
        vector<int> far(26, 0), ans;
        for(int i=0;i<n;i++)
        {
            far[s[i] - 'a'] = i;
        }

        int his_mx = 0, mx = -1;
        for(int i=0;i<n;i++)
        {
            his_mx = max(far[s[i]-'a'], his_mx);

            if(i == his_mx)
            {
                ans.push_back(his_mx-mx);
                mx = his_mx;
            }
        }

        return ans;
    }
};
相关推荐
写代码写到手抽筋2 小时前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.2 小时前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz113 小时前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
8Qi83 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
三品吉他手会点灯4 小时前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
乐迪信息4 小时前
乐迪信息:AI算法盒子实时识别船舶烟雾与火焰异常
大数据·人工智能·算法·安全·目标跟踪
J-Tony114 小时前
【JVM】根可达算法
jvm·算法
艾iYYY4 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
Lsk_Smion4 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode