zoukankan      html  css  js  c++  java
  • Javascript实现HashTable类

    散列算法可以尽快在数据结构中找出指定的一个值,因为可以通过Hash算法求出值的所在位置,存储和插入的时候都按照Hash算法放到指定位置。

    <script>
    
    function HashTable() {
    	this.table = [];
    }
    
    //loselose散列函数
    HashTable.prototype.loseloseHash = function(str){
    	var hash = 0;
    	for(var i=0; i<str.length; i++){
    		hash += str.charCodeAt(i);
    	}
    	return hash;
    }
    
    //增加/更新 散列表
    HashTable.prototype.put = function(key,value){
    	this.table[this.loseloseHash(key)] = value;
    	return this.loseloseHash(key);
    }
    
    //删除散列表一个值
    HashTable.prototype.remove = function(key){
    	this.table[this.loseloseHash(key)] = undefined;
    }
    
    //获取散列表的一个值
    HashTable.prototype.get = function(key){
    	return this.table[this.loseloseHash(key)];
    }
    
    var hashtable = new HashTable();
    console.log(hashtable.put('Zhangsan','zhangsan@gmail.com')); //826
    console.log(hashtable.put('Jay','jay@foxmail.com')); //292
    console.log(hashtable.put('Ken','ken@126.com'));  //286
    console.log(hashtable.get('Jay')); //jay@foxmail.com
    hashtable.remove('Jay');
    console.log(hashtable.get('Jay')); //undefined
    </script>
    
  • 相关阅读:
    搭建vue开发环境的步骤
    widow怎么结束某端口占用
    替换数据库表中某个代码段中某个字段的某一段字符串sql
    sql优化
    scssmap对象访问
    IntelliJ IDEA 和 webstorm更换主题
    css滚动条样式
    redis set
    【LeetCode】128. 最长连续序列
    第二章 模型评估
  • 原文地址:https://www.cnblogs.com/jaychan/p/5976429.html
Copyright © 2011-2022 走看看