★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆号:山青詠芝(shanqingyongzhi)
➤部落格園位址:山青詠芝(https://www.cnblogs.com/strengthen/ )
➤GitHub位址:https://github.com/strengthen/LeetCode
➤原文位址:https://www.cnblogs.com/strengthen/p/10449578.html
➤如果連結不是山青詠芝的部落格園位址,則可能是爬取作者的文章。
➤原文已修改更新!強烈建議點選原文位址閱讀!支援作者!支援原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
類似于C++中的find()函數:比較等于val的範圍中第一個元素的疊代器。如果沒有元素比對,則函數最後傳回。
傳回值是子字元串在父字元串中的位置(下标記錄),
如果沒有找到,那麼會傳回一個特别的标記npos(-1)。
傳回值可以看成是一個Int型的數。
1 //String擴充
2 extension String {
3 // 截取字元串:從index到結束處
4 // - Parameter index: 開始索引
5 // - Returns: 子字元串
6 func subStringFrom(_ index: Int) -> String {
7 let theIndex = self.index(self.endIndex, offsetBy: index - self.count)
8 return String(self[theIndex..<endIndex])
9 }
10
11 //從0索引處開始查找是否包含指定的字元串,傳回Int類型的索引
12 //傳回第一次出現的指定子字元串在此字元串中的索引
13 func findFirst(_ sub:String)->Int {
14 var pos = -1
15 if let range = range(of:sub, options: .literal ) {
16 if !range.isEmpty {
17 pos = self.distance(from:startIndex, to:range.lowerBound)
18 }
19 }
20 return pos
21 }
22
23 //從0索引處開始查找是否包含指定的字元串,傳回Int類型的索引
24 //傳回最後出現的指定子字元串在此字元串中的索引
25 func findLast(_ sub:String)->Int {
26 var pos = -1
27 if let range = range(of:sub, options: .backwards ) {
28 if !range.isEmpty {
29 pos = self.distance(from:startIndex, to:range.lowerBound)
30 }
31 }
32 return pos
33 }
34
35 //從指定索引處開始查找是否包含指定的字元串,傳回Int類型的索引
36 //傳回第一次出現的指定子字元串在此字元串中的索引
37 func findFirst(_ sub:String,_ begin:Int)->Int {
38 var str:String = self.subStringFrom(begin)
39 var pos:Int = str.findFirst(sub)
40 return pos == -1 ? -1 : (pos + begin)
41 }
42
43 //從指定索引處開始查找是否包含指定的字元串,傳回Int類型的索引
44 //傳回最後出現的指定子字元串在此字元串中的索引
45 func findLast(_ sub:String,_ begin:Int)->Int {
46 var str:String = self.subStringFrom(begin)
47 var pos:Int = str.findLast(sub)
48 return pos == -1 ? -1 : (pos + begin)
49 }
50 }
測試代碼:
1 var str:String = "Strengthen"
2 print(str.findFirst("e",4))
3 //Print 8
4 print(str.findLast("e",2))
5 //Print 8
6 print(str.findLast("e",3))
7 //Print 8
轉載于:https://www.cnblogs.com/strengthen/p/10449578.html