You are given a string s. s[i] is either a lowercase English letter or
'?'.
For a string t having length m containing only lowercase English letters, we define the function cost(i) for an index i as the number of characters equal to t[i] that appeared before it, i.e. in the range [0, i - 1].
The value of t is the sum of cost(i) for all indices i.
For example, for the string t = "aab":
cost(0) = 0
cost(1) = 1
cost(2) = 0
Hence, the value of "aab" is 0 + 1 + 0 = 1.
Your task is to replace all occurrences of '?' in s with any lowercase English letter so that the value of s is minimized.
Return a string denoting the modified string with replaced occurrences of'?'. If there are multiple strings resulting in theminimum value , return the lexicographically smallest one.
Input: s ="???"Output: "abc"Explanation: In this example, we can replace the occurrences of `'?'` to
make `s` equal to `"abc"`.For `"abc"`,`cost(0) = 0`,`cost(1) = 0`, and `cost(2) = 0`.The value of `"abc"`is`0`.Some other modifications of `s` that have a value of `0` are `"cba"`,`"abz"`,and,`"hey"`.Among all of them, we choose the lexicographically smallest.
Input: s ="a?a?"Output: "abac"Explanation: In this example, the occurrences of `'?'` can be replaced to
make `s` equal to `"abac"`.For `"abac"`,`cost(0) = 0`,`cost(1) = 0`,`cost(2) = 1`, and `cost(3) = 0`.The value of `"abac"`is`1`.
To minimize the value, we want to avoid repeating any letter as much as possible. For each ‘?’, we should pick the smallest lexicographical letter that hasn’t appeared before in the string so far. If all 26 letters have appeared, pick ‘a’.
funminimizeValue(s: String): String {
val used = mutableSetOf<Char>()
val arr = s.toCharArray()
for (i in arr.indices) {
if (arr[i] =='?') {
var found = falsefor (c in'a'..'z') {
if (c !in used) {
arr[i] = c
found = truebreak }
}
if (!found) arr[i] = 'a' used.add(arr[i])
} else {
used.add(arr[i])
}
}
return String(arr)
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
defminimizeValue(s: str) -> str:
used = set()
res = list(s)
for i in range(len(res)):
if res[i] =='?':
for c in map(chr, range(ord('a'), ord('z')+1)):
if c notin used:
res[i] = c
breakif res[i] =='?':
res[i] ='a' used.add(res[i])
else:
used.add(res[i])
return''.join(res)