小念子

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

题意:

字符串S和 T 只包含小写字符。在S中,所有字符只会出现一次。

S 已经根据某种规则进行了排序。我们要根据S中的字符顺序对T进行排序。更具体地说,如果S中x在y之前出现,那么返回的字符串中x也应出现在y之前。

返回任意一种符合条件的字符串T。

示例:

输入:
S = "cba"
T = "abcd"

输出: "cbad"

解释:
S中出现了字符 "a", "b", "c", 所以 "a", "b", "c" 的顺序应该是 "c", "b", "a".
由于 "d" 没有在S中出现, 它可以放在T的任意位置. "dcba", "cdba", "cbda" 都是合法的输出。

注意:

S的最大长度为26,其中没有重复的字符。

T的最大长度为200。

S和T只包含小写字符。

解答:

1、使用map记录记录字符顺序,key-字符,value-下标(范围在[0,25]之间)

2、根据map中key对应的value,对T进行排序。(若map中不存在该key,则默认值是26,默认排序在最后)

代码如下:

    public String customSortString(String S, String T) {
        StringBuilder stringBuilder = new StringBuilder();
        Map<Character, Integer> map = new HashMap<Character, Integer>();
        for (int i = 0; i < S.length(); ++i) {
            map.put(S.charAt(i), i);
        }
        Character[] charArr = new Character[T.length()];
        for (int i = 0; i < T.length(); ++i) {
            charArr[i] = T.charAt(i);
        }
        Arrays.sort(charArr, new Comparator<Character>() {

            @Override
            public int compare(Character arg0, Character arg1) {
                // TODO Auto-generated method stub
                int value0 = map.getOrDefault(arg0, 26);
                int value1 = map.getOrDefault(arg1, 26);
                return value0 - value1;
            }
        });
        for (int i = 0; i < charArr.length; ++i) {
            stringBuilder.append(charArr[i]);
        }
        return stringBuilder.toString();
    }

 

posted on 2020-10-15 19:52  小念子  阅读(113)  评论(0编辑  收藏  举报