问题描述:给你一个字符串 s 和一个 长度相同 的整数数组 indices 。
请你重新排列字符串 s ,其中第 i 个字符需要移动到 indices[i] 指示的位置。
返回重新排列后的字符串。
示例 1:
输入:s = "codeleet", indices = [4,5,6,7,0,2,1,3]
输出:"leetcode"
解释:如图所示,"codeleet" 重新排列后变为 "leetcode" 。
示例 2:
输入:s = "abc", indices = [0,1,2]
输出:"abc"
解释:重新排列后,每个字符都还留在原来的位置上。
示例 3:
输入:s = "aiohn", indices = [3,1,4,2,0]
输出:"nihao"
代码实例(拿去即可运行):
public class RearrangeStrings {
public static void main(String[] args) {
int[] indices = {4, 5, 6, 7, 0, 2, 1, 3};
System.out.println(restoreString("codeleet", indices));
}
public static String restoreString(String s, int[] indices) {
int length = s.length();
char[] result = new char[length];
for (int i = 0; i < length; i++) {
result[indices[i]] = s.charAt(i);
}
return new String(result);
}
}
运行结果:
我要刷100道算法题,第13道