• JavaScript 散列表(HashTable)


    TypeScript方式实现源码

    // 特性:
    // 散列算法的作用是尽可能快地在数据结构中找到一个值。 在之前的章节中, 你已经知道如果
    // 要在数据结构中获得一个值(使用get方法) ,需要遍历整个数据结构来找到它。如果使用散列
    // 函数,就知道值的具体位置,因此能够快速检索到该值。散列函数的作用是给定一个键值,然后
    // 返回值在表中的地址
    
    //  put(key,value):向散列表增加一个新的项(也能更新散列表)
    //  remove(key):根据键值从散列表中移除值
    //  get(key):返回根据键值检索到的特定的值
    //  loseloseHashCode(key):散列函数
    //  put(key):
     1 /**
     2  * 散列表
     3  * @desc 与Set类相似,ECMAScript 6同样包含了一个Map类的实现,即我们所说的字典
     4  */
     5 class HashTable {
     6     private table = [];
     7     public put(key, value) {
     8         let position = HashTable.loseloseHashCode(key);
     9         console.log('position' + '-' + key);
    10         this.table[position] = value;
    11     }
    12     public remove(key) {
    13         this.table[HashTable.loseloseHashCode(key)] = undefined;
    14     }
    15     public get(key) {
    16         return this.table[HashTable.loseloseHashCode(key)];
    17     }
    18     private static loseloseHashCode(key) {
    19         // 不够完善
    20         // let hash = 0;
    21         // for (let i = 0; i < key.length; i++) {
    22         //     hash += key.charCodeAt(i);
    23         // }
    24         // return hash % 37;
    25         // 更好的实现方式
    26         let hash = 5381;
    27         for (var i = 0; i < key.length; i++) {
    28             hash = hash * 33 + key.charCodeAt(i);
    29         }
    30         return hash % 1013;
    31     }
    32 }
    散列表 HashTable

    JavaScript方式实现源码

     1 /**
     2  * 散列表
     3  * @desc 与Set类相似,ECMAScript 6同样包含了一个Map类的实现,即我们所说的字典
     4  */
     5 var HashTable = (function () {
     6     function HashTable() {
     7         this.table = [];
     8     }
     9     HashTable.prototype.put = function (key, value) {
    10         var position = HashTable.loseloseHashCode(key);
    11         console.log('position' + '-' + key);
    12         this.table[position] = value;
    13     };
    14     HashTable.prototype.remove = function (key) {
    15         this.table[HashTable.loseloseHashCode(key)] = undefined;
    16     };
    17     HashTable.prototype.get = function (key) {
    18         return this.table[HashTable.loseloseHashCode(key)];
    19     };
    20     HashTable.loseloseHashCode = function (key) {
    21         // 不够完善
    22         // let hash = 0;
    23         // for (let i = 0; i < key.length; i++) {
    24         //     hash += key.charCodeAt(i);
    25         // }
    26         // return hash % 37;
    27         // 更好的实现方式
    28         var hash = 5381;
    29         for (var i = 0; i < key.length; i++) {
    30             hash = hash * 33 + key.charCodeAt(i);
    31         }
    32         return hash % 1013;
    33     };
    34     return HashTable;
    35 }());
    散列表 HashTable
  • 相关阅读:
    Gradview读取Excel表并插入数据库
    键盘上每个键作用!!! (史上最全的)­
    经典SQL语句大全
    [转帖] 一个老乞丐的一句话,震惊全中国人!
    GridView控件实现自定义数字、时间、货币字符串格式
    .net连接数据库相关
    论坛Email验正的正则表达式升级
    自定义DBHelper类
    在线编辑器CuteEditor使用方法
    asp.net中验证码的生成
  • 原文地址:https://www.cnblogs.com/menu/p/6973110.html
Copyright © 2020-2023  润新知