《劍指offer》— JavaScript(34)第一個只出現(xiàn)一次的字符

第一個只出現(xiàn)一次的字符

題目描述

在一個字符串(1<=字符串長度<=10000,全部由大寫字母組成)中找到第一個只出現(xiàn)一次的字符,并返回它的位置。


思路

  1. 新建一個對象,其中key用來存放字符,value用來存放該字符出現(xiàn)的次數(shù);
  2. 第一次循環(huán),將所有字符和對應出現(xiàn)的次數(shù)存放在map中,時間復雜度為0(n);
  3. 第二次循環(huán)找到value為1的字符所在的位置,并返回。

實現(xiàn)代碼

function FirstNotRepeatingChar(str) {
    if (str.length == 0)
        return -1;

    var map = {};
    for (var i = 0; i < str.length; i++) {
        var charX = str[i]
        if (!map[charX]) {
            map[charX] = 1;
        } else {
            map[charX]++;
        }
    }

    for (var i = 0; i < str.length; i++) {
        var charY = str[i];
        if (map[charY ] == 1)
            return i;
    }
}
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內(nèi)部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,662評論 18 399
  • 紐約時間比加州時間早三個小時, 但是加州時間并沒有變慢。 有人22歲就畢業(yè)了, 但等了五年才找到穩(wěn)定的工作! 有人...
    步六孤新晴閱讀 374評論 0 0
  • 第一次接觸到 Kindle Oasis 是一位同事在剛上市不久買的,到手的第一感覺就是輕,薄,手感極佳,從此念念不...
    陳新濤閱讀 10,629評論 0 6
  • 一、看包裝 1.書名:《會生氣,你才會健康》 2.類別:心靈勵志 3.作者:瑪西亞·坎農(nóng) 4.作者等級: 5.策劃...
    胡小乙藥師閱讀 383評論 0 1

友情鏈接更多精彩內(nèi)容