JavaScript數(shù)據(jù)結(jié)構(gòu)與算法-散列練習(xí)

散列的實(shí)現(xiàn)

// 散列類 - 線性探測(cè)法
function HashTable () {
    this.table = new Array(137);
    this.values = [];
    this.simpleHash = simpleHash;
    this.betterHash = betterHash;
    this.showDistro = showDistro;
    this.put = put;
    this.get = get;
}
function put (key, data) {
    let pos = this.betterHash(key);
    // this.table[pos] = data;
    if (this.table[pos] === undefined) {
        this.table[pos] = key;
        this.values[pos] = data;
    } else {
        while (this.table[pos] !== undefined) {
            ++pos;
        }
        this.table[pos] = key;
        this.values[pos] = data;
    }
}
function get (key) {
    // return this.table[this.betterHash(key)];
    let hash = -1;
    hash = this.betterHash(key);
    if (hash > -1) {
        for (let i = hash; this.table[hash] !== undefined; ++i) {
            if (this.table[hash] === key) {
                return this.values[hash];
            }
        }
    }
    return undefined;
}
function simpleHash (data) {
    let total = 0;
    for (let i = 0; i < data.length; ++i) {
        total += data.charCodeAt(i);
    }
    return total % this.table.length;
}
function showDistro () {
    let n = 0;
    for (let i = 0; i < this.table.length; ++i) {
        if (this.table[i] !== undefined) {
            console.log(`${i}: ${this.table[i]}`);
        }
    }
}
function betterHash (string) {
    const H = 7;
    let total = 0;
    for (let i = 0; i < string.length; ++i) {
        total += H * total + string.charCodeAt(i);
    }
    total = total % this.table.length;
    if (total < 0) {
        total += this.table.length -1;
    }
    return parseInt(total, 10);
}

練習(xí)

使用線性探測(cè)法創(chuàng)建一個(gè)字典把沼,用來保存單詞的定義。該程序需要包含兩個(gè)部分:第一部分將一組單詞和它們的定義存儲(chǔ)進(jìn)散列表吁伺;第二部分讓用戶輸入單詞饮睬,程序給出該單詞的定義。

// 字典類
function Dict () {
    this.hashTable = new HashTable();
    this.save = save;
    this.find = find;
}
function save (word, description) {
    this.hashTable.put(word, description);
}
function find (word) {
    return this.hashTable.get(word);
}
// 示例
let d = new Dict();
d.save('Mazey', 'a strong man.');
d.save('Cherrie', 'a beautiful girl.');
d.save('John', 'unknown.');
console.log(d.find('John')); // unknown.
console.log(d.find('Mazey')); // a strong man.
console.log(d.find('Ada')); // undefined
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末篮奄,一起剝皮案震驚了整個(gè)濱河市捆愁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌窟却,老刑警劉巖昼丑,帶你破解...
    沈念sama閱讀 218,546評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異夸赫,居然都是意外死亡矾克,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來胁附,“玉大人酒繁,你說我怎么就攤上這事】仄蓿” “怎么了州袒?”我有些...
    開封第一講書人閱讀 164,911評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)弓候。 經(jīng)常有香客問我郎哭,道長(zhǎng),這世上最難降的妖魔是什么菇存? 我笑而不...
    開封第一講書人閱讀 58,737評(píng)論 1 294
  • 正文 為了忘掉前任夸研,我火速辦了婚禮,結(jié)果婚禮上依鸥,老公的妹妹穿的比我還像新娘亥至。我一直安慰自己,他們只是感情好贱迟,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評(píng)論 6 392
  • 文/花漫 我一把揭開白布姐扮。 她就那樣靜靜地躺著,像睡著了一般衣吠。 火紅的嫁衣襯著肌膚如雪茶敏。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,598評(píng)論 1 305
  • 那天缚俏,我揣著相機(jī)與錄音惊搏,去河邊找鬼。 笑死忧换,一個(gè)胖子當(dāng)著我的面吹牛恬惯,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播包雀,決...
    沈念sama閱讀 40,338評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼宿崭,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼亲铡!你這毒婦竟也來了才写?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,249評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤奖蔓,失蹤者是張志新(化名)和其女友劉穎赞草,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吆鹤,經(jīng)...
    沈念sama閱讀 45,696評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡厨疙,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了疑务。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片沾凄。...
    茶點(diǎn)故事閱讀 40,013評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡梗醇,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出撒蟀,到底是詐尸還是另有隱情叙谨,我是刑警寧澤,帶...
    沈念sama閱讀 35,731評(píng)論 5 346
  • 正文 年R本政府宣布保屯,位于F島的核電站手负,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏姑尺。R本人自食惡果不足惜竟终,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望切蟋。 院中可真熱鬧统捶,春花似錦、人聲如沸敦姻。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,929評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽镰惦。三九已至迷守,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間旺入,已是汗流浹背兑凿。 一陣腳步聲響...
    開封第一講書人閱讀 33,048評(píng)論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留茵瘾,地道東北人礼华。 一個(gè)月前我還...
    沈念sama閱讀 48,203評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像拗秘,于是被迫代替她去往敵國和親圣絮。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,146評(píng)論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理雕旨,服務(wù)發(fā)現(xiàn)扮匠,斷路器,智...
    卡卡羅2017閱讀 134,657評(píng)論 18 139
  • 霜降天寒凡涩,又到重陽棒搜。喜豐年,稻熟禾黃活箕。親朋相聚力麸,老少同堂。品杯中酒,碟中菜克蚂,碗中湯闺鲸。 太平盛世,民安國強(qiáng)埃叭,插茱萸翠拣,...
    萬子云閱讀 345評(píng)論 2 10
  • 我好想飛翔 像沒有翅膀的魚 像溫水里的青蛙 像冬日的草地 我好想飛翔 像花兒 像開心果 像真情 我真想飛翔 像樹葉...
    我是三色槿閱讀 185評(píng)論 0 0
  • 最近市場(chǎng)上有很多商家都在需求一款有推薦人式的會(huì)員管理系統(tǒng),推薦人能帶來什么效果呢游盲?可能很多人不知道误墓,這是一...
    程昂閱讀 633評(píng)論 0 0