我有一个字符串,可以说
var abc : String = "aaaabbbbbbbccddd"
我需要一种算法,用于将这些重复字母更改为重复字母的数量(如果连续超过2个),以便给定的字符串变为
abc = "a4b7ccd3"
任何提示将不胜感激。
答案 0 :(得分:4)
让我们以这个字符串开始:
let abc : String = "aaaabbbbbbbccddde"
并在新变量中添加输出
var result = ""
让我们使用索引来遍历字符串中的字符
var index = abc.startIndex
while index < abc.endIndex {
//There is already one character :
let char = abc[index]
var count = 0
//Let's check the following characters, if any
repeat {
count += 1
index = abc.index(after: index)
} while index < abc.endIndex && abc[index] == char
//and update the result accordingly
result += count < 3 ?
String(repeating: char, count: count) :
String(char) + String(count)
}
这是结果:
print(result) //a4b7ccd3e