假如我需要一个1-10之间的随机整数,而且我给定一个ID. 我想要根据ID去生成随机数, 如果ID不变,则生成的随机数就不变,如果ID改变则生成一个新的随机数 求指教
语言环境最好是:JavaScript
学习是最好的投资!
看了你的需求,目标集只有1~10十种情况,说它是随机数实在有点……
上代码吧,假设ID是字符串。
function generate(id){ var sum = 0; for(var i = 0; i < id.length; i++){ sum += id.charCodeAt(i); } return (sum % 10) + 1; } generate("foo"); // 5 generate("bar"); // 10 generate("segmentfault"); // 6 generate("stackoverflow"); // 9
这个算出来,分布肯定没有那么均匀,不过看了你的需求,应该不会太在意这个。
没有语言/场景很难回答啊,除了其他人提过的设seed以外,我提供另外一个思路吧:
利用hash算法,常见的md5/sha1之类都行,hash(ID + 'catonkeyboard') / 10 这样
hash(ID + 'catonkeyboard') / 10
比起seed来说,很可能慢不少,但好处在于hash算法是标准的,可以做到跨语言跨机器跨各种环境一致
看意思,其实是要找一个……哈希值?可以对于ID转换后的整数模10运算,然后对于从0-9每个数字自定义一种到1-10的一一映射就好了~~
如果不考虑并发的问题,只要每次都是重新设置随机数的seed为ID话,那么每次再生成的随机数就一样
同意一楼的看法,将ID设为seed,然后生成的随机数对10进行取模,如果结果为0,则修改为10,得到的就是1~10内的随机数了。
如果ID不变,则生成的随机数就不变,如果ID改变则生成一个新的随机数
只要你的算法的唯一变量(任意随机因素都是变量)是传入的ID,都能实现。
ID % 10 // 唯一变量 # 或者 (ID * random()) % 10 //有随机因素加入
问题不完整,不能让大家去猜你的问题。。。
随机。。。然后有定值。。 我想到的就是哈希之类的。(加密转化)之类的。
看了你的需求,目标集只有1~10十种情况,说它是随机数实在有点……
上代码吧,假设ID是字符串。
这个算出来,分布肯定没有那么均匀,不过看了你的需求,应该不会太在意这个。
没有语言/场景很难回答啊,除了其他人提过的设seed以外,我提供另外一个思路吧:
利用hash算法,常见的md5/sha1之类都行,
hash(ID + 'catonkeyboard') / 10
这样比起seed来说,很可能慢不少,但好处在于hash算法是标准的,可以做到跨语言跨机器跨各种环境一致
看意思,其实是要找一个……哈希值?可以对于ID转换后的整数模10运算,然后对于从0-9每个数字自定义一种到1-10的一一映射就好了~~
如果不考虑并发的问题,只要每次都是重新设置随机数的seed为ID话,那么每次再生成的随机数就一样
同意一楼的看法,将ID设为seed,然后生成的随机数对10进行取模,如果结果为0,则修改为10,得到的就是1~10内的随机数了。
只要你的算法的唯一变量(任意随机因素都是变量)是传入的ID,都能实现。
问题不完整,不能让大家去猜你的问题。。。
随机。。。然后有定值。。
我想到的就是哈希之类的。(加密转化)之类的。