1.题目描述:给定只含 “I”(增大)或 “D”(减小)的字符串 S ,令 N = S.length。
返回 [0, 1, …, N] 的任意排列 A 使得对于所有 i = 0, …, N-1,都有:
如果 S[i] == “I”,那么 A[i] < A[i+1]
如果 S[i] == “D”,那么 A[i] > A[i+1]
示例 1:
输入:“IDID”
输出:[0,4,1,3,2]
示例 2:
输入:“III”
输出:[0,1,2,3]
示例 3:
输入:“DDI”
输出:[3,2,0,1]
2.分析:’‘I’’,’‘D’’ 可以看做对应的数的增减趋势,’‘I’'表示下一个数会增,则我们把最小的数安排好,则下一个数必增,若还是"I",则把倒数第二小的数安排上,下一个数必增,符合"I"的趋势,以此类推,“D"同理。最后"i”,"j"指向同一个数。
3.代码如下:
class Solution {
public int[] diStringMatch(String s) {
int a[] = new int [s.length()+1];
int i=0;
int j=s.length();
for(int k=0;k<s.length();k++){
if(s.charAt(k) == 'I'){
a[k] = i;
i++;
}
else{
a[k] = j;
j--;
}
}
a[s.length()] = i;
return a;
}
}
后记:这道题自己做不出来,是看了别人的代码后自己加以分析的。
本文探讨了如何根据含'I'(增大)或'D'(减小)的字符串S生成[0,1,...,N]的排列A,使A的元素按S指示的增减趋势排列。通过实例展示了算法实现,如IDID生成[0,4,1,3,2]等。
1270

被折叠的 条评论
为什么被折叠?



