HashTable实现原理

使用语言: C#


写在前面

好久没写简书,一上来看到那么多朋友的关注和点赞,突然感觉继续写点内容分享一下。
最近正好离职在家,跟网易和腾讯的大牛们,聊了很多底层实现和数据结构的内容,借这个机会写一些,我相信对大家肯定有帮助的。
19年立下大志,把lua底层源码核心内容写在简书中!
19年立下大志,把引擎底层的物理系统整理到简书中!
19年立下大志,把数据结构的应用写到简书中!
个人感觉精通以上三点足矣,进入网易和腾讯都不是问题,说明一下不管你熟不熟悉unity还是ue,对于客户端而言都不是很重要哦。


文章内容:

   1. 介绍hashtable的面试问题
   2. 使用Csharp语言实现hashtable

问题:

 1.  hashtable底层实现了解吗?
 2.  hashtable中查找key时,时间复杂度时多少?

解答

  1. hashtable采用的数据结构是散列表,如下图所示,0,1,2,3是索引,指针指向的是对应的key和value值。(不明白?很正常,往下看。)
image.png
  1. hashtable查找key的时间复杂度为O(1)-O(n),即最好情况下为O(1),最差情况下为O(N),查找速度很是很不错的哦。
    这里解释一下,当我们存放key-value为“name”-"mashuai"时, key->name存到hashtable中前,先把字符串“name”转换为hashcode(这是一个整形数值哦)如下,这个hashcode经过数据算法就是hashtable的index索引,也是我们上面散列表的index。
    string key = "name";
    Console.WriteLine (key.GetHashCode()); //62725243
    hashcode = (key.GetHashCode() & int.MaxValue) % table.length
  • 注意: string -> hashcode 有好多种算法,自己百度查一下即可。需要注意一点,“name” 和“xxxx”很可能是同一个hashcode。

源码实现(初版。。。很多改进的,主要是put/get思想)

    // HashTable的Node结构
class MyHashEntery<K, V>
{
    public int hash;     // key's hashcode 
    public K key;
    public V value;
    public MyHashEntery<K,V> next;

    public MyHashEntery(int _h, K _k, V _v, MyHashEntery<K,V> _n)
    {
        this.hash = _h;
        this.key = _k;
        this.value = _v;
        this.next = _n;
    }
}

class MyHashTable<K, V>
{
    private MyHashEntery<K,V> [] table;  
    private int count;
    private int threshold;
    private float loadFactor;

    public int Count
    {
        get{return count;}
    }

    public MyHashTable()
    {
        table = new MyHashEntery<K, V>[5];
        count = 0;
        threshold = 10;
    }

    public void Put(K _k, V _v)
    {
        if(_v == null){ throw new Exception("myhashtable's value can't be null!");}

        MyHashEntery<K,V>[] tab = table;

        int hash = _k.GetHashCode();
        int index = (hash & int.MaxValue) % tab.Length;

        MyHashEntery<K,V> temp = tab[index];

        // check key if exist
        while(temp != null)
        {
            if((temp.hash == hash) && temp.key.Equals(_k))
            {
                throw new Exception("key is existed!");
            }
            temp = temp.next;
        }

        if(count >= threshold)
        {
            // expand hashtable  !!temp!!
            threshold = threshold * 2;
            MyHashEntery<K,V>[] newTable = new MyHashEntery<K, V>[table.Length + 5];
            for(int i = 0; i < table.Length; i++)
            {
                newTable[i] = table[i];
            }
            table = newTable;

            tab = table;
            index = (hash & int.MaxValue) % tab.Length;
        }
        MyHashEntery<K,V> e = tab[index];
        tab[index] = new MyHashEntery<K, V>(hash, _k, _v, e);

        count++;
    }

    public V Get(K _k)
    {
        int hash = _k.GetHashCode();
        int index = (hash & int.MaxValue) % table.Length;

        MyHashEntery<K, V> e = table[index];
        while(e != null)
        {
            if(e.hash == hash && e.key.Equals(_k))
            {
                return e.value;
            }
        }

        return default(V);
    }

}
    class MainClass
{
    public static void Main (string[] args)
    {
        MyHashTable<string, string> hash = new MyHashTable<string, string>();
        hash.Put("name1", "35");
        hash.Put("name2", "lua");

        hash.Put("name3", "python");
        
        Console.WriteLine (hash.Get("name1"));
    }
}

写在最后

 #成功的道路没有捷径,唯有不懈的努力,多研究一些底层源码才是王道。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容