halo321 2015-04-23 12:54 采纳率: 0%
浏览 3167

我这个hash函数对么?求出的hash值是0-9之间的一串数字,怎么转换为二进制的数字?

public long Ghash(char[] h)
{
    long hash = 0;
    for (int i = 0; i < h.Length; i++)
    {
        hash = Convert.ToInt64( hash * 31 + h[i]);
    }
    return hash;
}
  • 写回答

2条回答 默认 最新

  • threenewbee 2015-04-23 12:57
    关注

    你这样比较容易溢出。当h比较长的时候。
    hash函数无所谓对错,只要满足,相同的输入,输出相同,不同的输入,结果可以相同也可以不同,但是最好不同,就可以了。

    评论

报告相同问题?

悬赏问题

  • ¥15 聚类分析或者python进行数据分析
  • ¥15 如何用visual studio code实现html页面
  • ¥15 逻辑谓词和消解原理的运用
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?