LeetCode #833 - Find And Replace in String

题目描述:

To some string S, we will perform some replacement operations that replace groups of letters with new ones (not necessarily the same size).

Each replacement operation has 3 parameters: a starting index i, a source word x and a target word y.  The rule is that if x starts at position i in the original string S, then we will replace that occurrence of x with y.  If not, we do nothing.

For example, if we have S = "abcd" and we have some replacement operation i = 2, x = "cd", y = "ffff", then because "cd" starts at position 2 in the original string S, we will replace it with "ffff".

Using another example on S = "abcd", if we have both the replacement operation i = 0, x = "ab", y = "eee", as well as another replacement operation i = 2, x = "ec", y = "ffff", this second operation does nothing because in the original string S[2] = 'c', which doesn't match x[0] = 'e'.

All these operations occur simultaneously.  It's guaranteed that there won't be any overlap in replacement: for example, S = "abc", indexes = [0, 1], sources = ["ab","bc"] is not a valid test case.

Example 1:

Input: S = "abcd", indexes = [0,2], sources = ["a","cd"], targets = ["eee","ffff"]

Output: "eeebffff"

Explanation: "a" starts at index 0 in S, so it's replaced by "eee".

"cd" starts at index 2 in S, so it's replaced by "ffff".

Example 2:

Input: S = "abcd", indexes = [0,2], sources = ["ab","ec"], targets = ["eee","ffff"]

Output: "eeecd"

Explanation: "ab" starts at index 0 in S, so it's replaced by "eee". 

"ec" doesn't starts at index 2 in the original S, so we do nothing.

Notes:

1. 0 <= indexes.length = sources.length = targets.length <= 100

2. 0 < indexes[i] < S.length <= 1000

3. All characters in given inputs are lowercase letters.

给定下标,从字符串中寻找source替换成target,由于需要从头到尾一次替换生成新的字符串,所以需要对下标排序,依次替换。

class X{
public:
    int index;
    string source;
    string target;
    X(int i, string s, string t) : index(i), source(s), target(t) {}
};

class Solution {
public:
    static bool comp(X a, X b)
    {
        if(a.index<b.index) return true;
        else return false;
    }
    
    string findReplaceString(string S, vector<int>& indexes, vector<string>& sources, vector<string>& targets) {
        vector<X> v;
        for(int i=0;i<indexes.size();i++)
        {
            X temp(indexes[i],sources[i],targets[i]);
            v.push_back(temp);
        }
        sort(v.begin(),v.end(),comp);
        
        string result;
        int i=0;
        int j=0;
        while(i<S.size()&&j<v.size())
        {
            if(i==v[j].index)
            {
                if(S.substr(v[j].index,v[j].source.size())==v[j].source)
                {
                    result+=v[j].target;
                    i+=v[j].source.size();
                    j++;
                }
                else
                {
                    result+=S[i];
                    i++;
                    j++;
                }
            }
            else
            {
                result+=S[i];
                i++;
            }
        }
        result+=S.substr(i);
        return result;
    }
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值