JavaScript數據結構與算法-散列練習

散列的實現

// 散列類 - 線性探測法
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);
}

練習

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

// 字典類
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
?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,323評論 25 708
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發(fā)現,斷路器,智...
    卡卡羅2017閱讀 136,695評論 19 139
  • 霜降天寒,又到重陽。喜豐年,稻熟禾黃。親朋相聚,老少同堂。品杯中酒,碟中菜,碗中湯。 太平盛世,民安國強,插茱萸,...
    萬子云閱讀 410評論 2 10
  • 我好想飛翔 像沒有翅膀的魚 像溫水里的青蛙 像冬日的草地 我好想飛翔 像花兒 像開心果 像真情 我真想飛翔 像樹葉...
    我是三色槿閱讀 218評論 0 0
  • 最近市場上有很多商家都在需求一款有推薦人式的會員管理系統,推薦人能帶來什么效果呢?可能很多人不知道,這是一...
    程昂閱讀 690評論 0 0

友情鏈接更多精彩內容