Problem
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:
S string length is in [1, 10000].
C is a single character, and guaranteed to be in string S.
All letters in S and C are lowercase.
</>复制代码
class Solution {
public int[] shortestToChar(String S, char C) {
int len = S.length();
int[] res = new int[len];
if (S == null || S.length() == 0) return res;
Arrays.fill(res, 10000);
int pre = -1;
for (int i = 0; i < len; i++) {
char ch = S.charAt(i);
if (ch == C) {
pre = i;
res[i] = 0;
} else {
if (pre != -1) {
res[i] = i-pre;
}
}
}
pre = -1;
for (int i = len-1; i >= 0; i--) {
char ch = S.charAt(i);
if (ch == C) {
pre = i;
} else {
if (pre != -1) {
res[i] = Math.min(res[i], pre-i);
}
}
}
return res;
}
}
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/76813.html
摘要:返回字符串中每一个字符离给定的字符的最短距离。否则,当当前下标大于上一个出现字符的位置,且存在下一个字符时,距离为两者中最小的那个。最终代码若觉得本文章对你有用,欢迎用爱发电资助。 D49 821. Shortest Distance to a Character 题目链接 821. Shortest Distance to a Character 题目分析 给定一个字符串s和一个字符...
摘要:代码第一次写入就先不比较第一次写入就先不比较哈希表法复杂度时间空间思路因为会多次调用,我们不能每次调用的时候再把这两个单词的下标找出来。我们可以用一个哈希表,在传入字符串数组时,就把每个单词的下标找出存入表中。 Shortest Word Distance Given a list of words and two words word1 and word2, return the ...
Problem You want to build a house on an empty land which reaches all buildings in the shortest amount of distance. You can only move up, down, left and right. You are given a 2D grid of values 0, 1 or...
Problem Design a class which receives a list of words in the constructor, and implements a method that takes two words word1 and word2 and return the shortest distance between these two words in the l...
Problem Given a list of words and two words word1 and word2, return the shortest distance between these two words in the list. Example:Assume that words = [practice, makes, perfect, coding, makes]. In...
阅读 3705·2021-09-06 15:13
阅读 1671·2021-09-02 10:19
阅读 2615·2019-08-30 15:52
阅读 1054·2019-08-29 15:25
阅读 1713·2019-08-26 18:36
阅读 660·2019-08-26 13:23
阅读 1481·2019-08-26 10:46
阅读 3641·2019-08-26 10:41