javascript數(shù)據(jù)結構之串的概念與用法分析
本文實例講述了javascript數(shù)據(jù)結構之串的概念與用法。分享給大家供大家參考,具體如下:
串是由零個或多個字符組成的有限序列。串中字符的個數(shù)稱為串的長度。
串中任意個連續(xù)的字符組成的子序列稱為該串的子串。包含子串的串相應地稱為主串。通常稱字符在序列中的序號為該字符在串中的位置。子串的首字符在主串中首次出現(xiàn)的位置定義為子串在主串中的位置。
串的邏輯結構和線性表十分相似,區(qū)別僅僅在于串的數(shù)據(jù)對象約束為字符集。然而兩者的基本操作有很大差別。線性表中,基本以單個元素來進行操作;而串中多半以串的整體也就是子串來作為操作對象。
JavaScript有很多串的方法嗎,具體的請查閱api。
https://developer.mozilla.org/en-US/
這里我們挑一個來看看,比如indexOf,該方法返回String對象內(nèi)第一次出現(xiàn)子字符串位置。如果沒有找到子字符串,則返回-1。我們來模擬一下這個方法的實現(xiàn):
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> </head> <body> <script type="text/javascript"> function index(a,b,pos){ //a為主串,b為要尋找的子串,pos為開始尋找的位置 if(pos>0){ var a_len=a.length, b_len=b.length, i=pos; while(i<=a_len-b_len+1){ //從第i個位置取和子串長度相等的進行比較,如果沒有找到則繼續(xù)i+1 var c=a.substr(i,b_len); if(c==b) return i; i++; } } return false; } var a="abcdefg"; var b="def"; var c=index(a,b,1); alert(c);//3 alert(a.indexOf(b,1));//3 </script> </body> </html>
這個思想其實很簡單,就是在主串中取從第i個字符起,長度和要尋找的串相等的子串進行比較,直到找到為止。所以說我們在運用一些原生的api時,如果能夠知道其實現(xiàn)的原理,就可以更好的駕馭它們。當然,該方法還可以改進,我在以后的文章中會介紹的。
更多關于JavaScript相關內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結構與算法技巧總結》、《JavaScript數(shù)學運算用法總結》、《JavaScript排序算法總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript查找算法技巧總結》及《JavaScript錯誤與調(diào)試技巧總結》
希望本文所述對大家JavaScript程序設計有所幫助。
相關文章
為非IE瀏覽器添加mouseenter,mouseleave事件的實現(xiàn)代碼
為非IE瀏覽器添加mouseenter,mouseleave事件的實現(xiàn)代碼,學習js的朋友可以參考下。2011-06-06微信小程序云開發(fā)實現(xiàn)分頁刷新獲取數(shù)據(jù)
這篇文章主要為大家詳細介紹了微信小程序云開發(fā)實現(xiàn)分頁刷新獲取數(shù)據(jù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-08-08JavaScript實現(xiàn)阿拉伯數(shù)字和中文數(shù)字互相轉換
JavaScript實現(xiàn)阿拉伯數(shù)字和中文數(shù)字互相轉換可以用數(shù)組的循環(huán)檢測后的替換來實現(xiàn),下面主要講解其中的一些核心算法:2016-06-06