如何将两个正整数映射为一个唯一的整数
How to map two positive integers to a unique integer?
我需要在给定两个整数的情况下找到一个唯一的整数。也就是说,给定两个整数x和y,我想找到一个函数f…,它将这些整数唯一地映射到另一个整数z,z=f(x,y)
这里x=64位整数,y=64位的整数。我想把这些数字映射到z,这样它又是一个64位整数。
我尝试了Cantors配对函数,但Cantors对函数返回给我一个"z",它是128位,因为Cantors成对函数中涉及乘法。我不希望z映射到128位,因为现代计算机的处理限制只有64位。
有出路吗。一点点碰撞对我来说是可以接受的。
如果您想对整个64位整数范围执行此操作,那么这是不可能的。
函数有2^64 * 2^64 = 2^128
个可能的输入,但只有2^64
个不同的输出,这意味着必须至少有2^64
个数字映射到同一整数,这远远大于a little bit of collision
您实际上是在寻找一个64位的散列函数。这是一份清单http://en.wikipedia.org/wiki/List_of_hash_functions
也许"锅炉板"这个功能会有所帮助?
unsigned long long f(
unsigned long long x,
unsigned long long y
)
{
/** many options here, including those in link provided by @xosp7tom's answer... **/
return(x*y);
}
相关文章:
- C++需要帮助从用户那里获得一个整数,并确保它在另外两个整数之间
- 当我们从/tp地址中添加/减去一个整数时会发生什么
- 如何将一个数组值合并为一个整数c++
- 为什么有时我输入一个整数,程序将第一个输入的数字打印成十进制数?
- 给定一个整数数组,需要在Max_Heap上运行操作。得到错误"segmentation fault",有什么想法吗?(C++)
- 我可以将迭代器递增一个整数吗?
- 有没有办法生成一个包含平方的序列,这些平方加起来就是一个整数平方?
- 我正在尝试制作一个程序,在添加 n 天(整数)后告诉一个人什么是一天(例如星期一等)
- 为什么将两个浮点数相加会得到一个整数C++?
- 编写一个读取五个整数并执行一些任务的C++程序
- 如果我们在其中输入一个整数,则字符会给出整数作为输出,但是当分配给它一个整数时,这不会发生。为什么?
- 给枚举一个整数,并在 C++ 中将其相关值作为字符串获取
- 我需要编写一个程序来读取一个文件,该文件将输出所有唯一的整数,如果已经看到整数,它将被关闭
- 按升序输出整数时,将最后一个整数放在新行上
- 编写一个程序,提示用户输入一个整数,然后输出数字的单个数字和数字的总和
- 我在c++中遇到了一个奇怪的错误,其中一个计算2个小整数加法的语句溢出到一个长值中
- 如何在C++中将一个值拆分为一个十进制整数
- 给定一个整数 N>0,区间 [0, 2^N) 中有多少个整数正好有 N-1 个设置位?编写一个返回正确答案的简短函数
- 我必须更改我的数字最后一个数字和第一个数字,但不要使用仅带有整数或循环的函数.例如从 12345 到 52341
- 将整数范围映射到另一个范围