关于php:LeetCode-763PHP-求解划分字母区间

48次阅读

共计 1278 个字符,预计需要花费 4 分钟才能阅读完成。

原文链接:何晓东 博客

划分字母区间

字符串 S 由小写字母组成。咱们要把这个字符串划分为尽可能多的片段,同一个字母只会呈现在其中的一个片段。返回一个示意每个字符串片段的长度的列表。

示例 1:

输出:S = "ababcbacadefegdehijhklij"
输入:[9,7,8]
解释:划分后果为 "ababcbaca", "defegde", "hijhklij"。每个字母最多呈现在一个片段中。像 "ababcbacadefegde", "hijhklij" 的划分是谬误的,因为划分的片段数较少。

提醒:

S 的长度在 [1, 500] 之间。
S 只蕴含小写字母 ‘a’ 到 ‘z’。

起源:力扣(LeetCode)
链接:https://leetcode-cn.com/probl…
著作权归领扣网络所有。商业转载请分割官网受权,非商业转载请注明出处。

解题思路 1

想切割,要有首尾两个指针,确定了结尾指针,就能确定下一个切割的开始指针。
遍历字符串,如果已扫描局部的所有字符,都只呈现在已扫描的范畴内,即可做切割。
下图已扫描的绿色字符,对应的最远地位,都不超过 8,在 8 这切一刀,[0:8] 的字符都不会呈现在别处。

maintain「已扫描的字符能去到的最远地位」,扫到这个地位就切割,切出的字符不会在之后呈现。
更新开始指针,筹备下一次切割。

一些变量

  • maxPos 一个 Map,记录每个字母对应的最远地位。
  • start 做切割的开始地位。
  • scannedCharMaxPos 已扫描的字符能去到的最远地位。

作者:xiao_ben_zhu
链接:https://leetcode-cn.com/probl…
起源:力扣(LeetCode)
著作权归作者所有。商业转载请分割作者取得受权,非商业转载请注明出处。

class Solution {

    /**
     * @param String $S
     * @return Integer[]
     */
    function partitionLabels($S) {$maxPos = [];
        $length = strlen($S);
        for ($i = 0; $i < $length; $i++) { // 寄存字母与它的最远地位
            $maxPos[$S[$i]] = $i;
        }

        $res = [];
        $start = 0;                        // 待切割的起始地位
        $scannedCharMaxPos = 0;            // 已扫描的字符中最远的地位

        for ($i = 0; $i < $length; $i++) {$curCharMaxPos = $maxPos[$S[$i]]; // 以后扫描的字符的最远地位
            $scannedCharMaxPos = max($scannedCharMaxPos, $curCharMaxPos); // 更新「已扫描的字符中最远的地位」if ($i == $scannedCharMaxPos) { // 正好扫描到「已扫描的字符的最远地位」,达到切割点
                $res[] = $i - $start + 1;
                $start = $i + 1;              // 更新,下一个待切割的字符串的起始地位
            }
        }
        return $res;
    }
}

参考链接:

  1. 『手画图解』划分字母区间 | 记录最远地位

最初恰饭 阿里云全系列产品 / 短信包特惠购买 中小企业上云最佳抉择 阿里云外部优惠券

正文完
 0