zoukankan      html  css  js  c++  java
  • leetcode-821-Shortest Distance to a Character

    题目描述:

    Given a string S and a character C, return an array of integers representing the shortest distance from the character C in the string.

    Example 1:

    Input: S = "loveleetcode", C = 'e'
    Output: [3, 2, 1, 0, 1, 0, 0, 1, 2, 2, 1, 0]
    

     

    Note:

    1. S string length is in [1, 10000].
    2. C is a single character, and guaranteed to be in string S.
    3. All letters in S and C are lowercase.

     

    要完成的函数:

    vector<int> shortestToChar(string S, char C) 

     

    说明:

    1、给定一个字符串S和字符C,找到字符串S中字符C的位置(可能有多个字符C),返回字符串S中所有字符距离最近的字符C的距离。

    比如S为leetcode,C为e,那么返回的距离vector就是[3, 2, 1, 0, 1, 0, 0, 1, 2, 2, 1, 0]。

    2、这道题题意很清晰,也有点像之前做过的一道题,笔者在这里模仿那道题的做法。

    给一个例子说明一下,比如S为leetcodell,C为e。

    那么我们先把每个字符都跟它右边或者本身的e比较距离,如果右边没有e了,那么插入INT_MAX。

    遍历一遍字符串S,我们可以得到[1,0,0,4,3,2,1,0,INT_MAX,INT_MAX]。

    接着我们再把每个字符都跟它左边或者本身的e比较距离,这个距离跟上述得到的距离,取一个最小值。如果左边没有e了,那么不做处理。

    遍历一遍字符串S,最后得到的距离vector就是我们要的了。

    上述做法,其实是把每个左边有e右边也有e的字符,计算一下距离左边的距离,再计算一下距离右边的距离,然后取一个最小值。

    对于那些只有右边有e的字符,只处理一次,对于只有左边有e的字符,也只处理一次。

    代码实现如下(附详解),分享给大家:

        vector<int> shortestToChar(string S, char C) 
        {
            vector<int>index;//记录S中C的位置
            vector<int>res;//最后要返回的距离vector
            int s1=S.size();
            for(int i=0;i<s1;i++)//不断插入C的位置
            {
                if(S[i]==C)
                    index.push_back(i);
            }
            int i=0,j=0,s2=index.size();
            while(i<s1)//计算每个字符跟右边C的距离
            {
                if(j<s2)//如果右边有C
                {
                    if(i<index[j])
                    {
                        res.push_back(index[j]-i);
                        i++;
                    }
                    else if((i==index[j]))
                    {
                        res.push_back(0);
                        j++;
                        i++;
                    }
                }
                else//如果右边没有C,那么插入INT_MAX
                {
                    res.push_back(INT_MAX);
                    i++;
                }
            }
            i=s1-1,j=s2-1;
            while(j>=0)//如果左边有C,计算每个字符跟左边C的距离
            {
                if(i>index[j])
                {
                    res[i]=min(res[i],i-index[j]);//只保留最小值
                    i--;
                }
                else if((i==index[j]))
                {
                    j--;
                    i--;
                }
            }
            return res;
        }
    

    上述代码实测15ms,因为服务器接受到的cpp submissions有限,所以没有打败的百分比。

  • 相关阅读:
    HDU-1215 七夕节 数论 唯一分解定理 求约数之和
    LightOJ-1259 Goldbach`s Conjecture 数论 素数筛
    [前端-动态数据可视化]横向柱状图的动态数据可视化
    CodeForces-722C Destroying Array 并查集 离线操作
    CodeForces-920E Connected Components? 广度搜索 双向链表 判断联通 大量重复节点的删除
    CodeForces-1007A Reorder the Array 贪心 田忌赛马
    POJ-3692 Kindergarten 二分图 最大团
    个人开发者做一款Android App需要知道的事情
    android各种组件的监听器
    留言处插入xss不弹框
  • 原文地址:https://www.cnblogs.com/chenjx85/p/9060001.html
Copyright © 2011-2022 走看看