Leetcode PHP题解--D63 917. Reverse Only Letters

博客围绕题目“917. Reverse Only Letters”展开,给定含符号字符串,需仅倒转字母顺序且不改变符号位置。思路是将字符串分为字母和符号两部分并保留其下标,抽离字母数组的键值,倒转值后合并到键数组,再覆盖原数组对应键。

D63 917. Reverse Only Letters

题目链接

917. Reverse Only Letters

题目分析

给定一个包含符号的字符串,仅倒转字母的出现顺序,不改变符号的出现位置。

思路

先把字符串分成字母和符号两部分,保留下标。
抽离字母数组的键和值,对值部分进行倒转,合并到键数组中。
再覆盖原数组中对应键即可。

最终代码

<?php
class Solution {

    /**
     * @param String $S
     * @return String
     */
    function reverseOnlyLetters($S) {
        $S = str_split($S);
        $chars = [];
        $others = [];
        foreach($S as $key=>$char){
            if(($char>='a' && $char<='z')
              || ($char>='A' && $char<='Z')
            ){
                $chars[$key] = $char;
            }
            else{
                $others[$key] = $char;
            }
        }
        $keys = array_keys($chars);
        $chars = array_reverse($chars);
        $chars = array_combine($keys,$chars);
        $S = $chars+$others;
        ksort($S);
        return implode('',$S);
    }
}

若觉得本文章对你有用,欢迎用爱发电资助。

转载于:https://my.oschina.net/u/2246923/blog/3050758

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值