智慧树要枯了 2016-05-27 15:18 采纳率: 37.5%
浏览 1305
已采纳

哈希算法问题,大家看看我的算法有问题吗?

图片说明
我输入(“ubuntu”,1007)的时候,我的结果被显示错误。

 class Solution {
    /**
     * @param key: A String you should hash
     * @param HASH_SIZE: An integer
     * @return an integer
     */
    public int hashCode(char[] key,int HASH_SIZE) {
        // write your code here
        int q=1;
        long result=0;
       int len=key.length;
        for(int i=len-1;i>-1;i--)
        {
            result=result+key[i]*q;
            q=q*33;
        }
       result= result % HASH_SIZE;
        return (int) result;
    }
};
  • 写回答

5条回答 默认 最新

  • ZSGG_ACM 2016-05-27 15:32
    关注

    你要注意q可能会溢出,在q=q*33下面加一行q=q%HASH_SIZE

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了