ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

c# – 值列表作为Map的键

2019-06-10 19:53:06  阅读:213  来源: 互联网

标签:c algorithm net data-structures f


我有可变长度列表,其中每个项目可以是四个唯一的一个,我需要用作地图中另一个对象的键.假设每个值可以是0,1,2或3(在我的实际代码中它不是整数,但更容易用这种方式解释)所以一些关键列表的例子可能是:

[1, 0, 2, 3]
[3, 2, 1]
[1, 0, 0, 1, 1, 3]
[2, 3, 1, 1, 2]
[1, 2]

因此,要重新迭代:列表中的每个项目可以是0,1,2或3,并且列表中可以有任意数量的项目.

我的第一种方法是尝试使用.NET中内置的GetHashCode()来散列数组的内容,以组合每个元素的哈希值.但由于这将返回一个int,我将不得不手动处理冲突(两个相等的int值与Dictionary相同).

所以我的第二种方法是使用四叉树,将列表中的每个项分解为一个节点,该节点有四个指针(每个可能值一个)到下四个可能的值(根节点表示[],一个空列表),插入[1,0,2] => Foo,[1,3] =>条和[1,0] => Baz进入这棵树看起来像这样:

Quad Tree Diagram http://episerversucks.com/upload/Diagram1111.png

灰色节点节点是未使用的指针/节点.虽然我担心这个设置的性能,但是不需要处理哈希冲突,树也不会变得很深(主要是存储2-6个项目的列表,很少超过6个).

有没有其他神奇的方法来存储带有值列表的项目作为我错过的键?

解决方法:

[编辑 – 更改答案以反映@gradbot和@Brian的评论]

你说你很少会有超过6个元素.如果您可以将最大值限制为14个元素,则可以使用GetHashCode().由于您只需要2位来存储该值,因此int中的32位将为您提供创建最多14个元素的唯一哈希码的可能性,并将0值考虑在内.

int[] arr = new [] { 1, 2, 3, 0, 1, 2, 3 };
public override int GetHashCode()
{
    if(arr.Length > 14) throw new Exception("max elems is 14");
    int hash = 1; // start with 1 to take into account a heading 0
    foreach (int i in arr)
    {
        hash = hash << 2;
        hash += i;
    }
    return hash;
}

如果你想使哈希值可逆,你也必须使用一些比特来表示长度.并且可以调整代码以允许15个元素以及@gradbot提到的元素.

标签:c,algorithm,net,data-structures,f
来源: https://codeday.me/bug/20190610/1213569.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有