在C++中实现哈希旋转方法的最佳方式是什么
What is the best way to implement a Hash rotation method in C++?
我正在努力理解哈希表和哈希方法(如除法和乘法),我想知道如何在键是串行的情况下实现旋转方法。假设我有一个名为int rotation(int value)
的函数,有一个类似int test = 123456
的整数,我想得到结果612345。实现这一点的最佳方式是什么(比如说使用1000个整数组的文本文件)?
int rotate(int value)
{
bool isNegative = value < 0;
if(isNegative)
value = -value;
int v = value % 10;
value /= 10;
while(v < value)
v *= 10;
value += v;
return isNegative ? -value : value;
}
这将根据密码的数量(123得到312,1234得到4123)旋转您的数字。
对于文件部分:您必须打开它,读取值,将它们转换为int,然后调用函数:
::std::ifstream in("filename");
if(in.fail())
{
// error
}
else
{
int n;
for(;;)
{
in >> n;
if(in.eof() || in.fail())
break;
::std::cout << rotate(n) << ::std::endl;
}
in.close();
}
相关文章:
- 在c代码之间共享数据的最佳方式
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 从嵌套在std::映射中的std::列表中删除元素的最佳方式
- 如果条件为TRUE(最佳方式?),则在do while循环中后置增量
- 在reactor中存储eventHandlers的最佳方式是什么
- 在AVX通道中混洗的最佳方式
- 从 T 创建 std::future 的最佳方式<T>
- C++:使用 std::unique_ptr 访问重载运算符++的最佳方式?
- 对列表列表中的元素进行分组的最佳方式
- 利用 GPU 的最佳方式
- 使用 QT C++过滤大数据的最佳方式
- 算法设计:用边界数字表示 2D 网格的最佳方式,以C++?
- 在C++中共享键值对的最佳方式
- 为Catch2中的外部文本文件指定路径的最佳方式
- 代表Quarto棋盘游戏棋子的最佳方式
- 等待线程的最佳方式是什么
- 将uint8_t*buffer和size_tbufferlen从C++传递到C中的API函数的最佳方式是什么
- 创建控制台菜单C++的最佳方式
- 只显示片段着色器的最佳方式是什么
- 复制文件的最佳方式是什么,以便我可以在复制过程中轻松取消复制?