如何在C++中准确地计算lops示例:计算哈希
How do for-lops exactly work in C++ example: calculating hashes
我试图找出在什么时间可以计算多少哈希。我使用的是SHA-512(具有512位输出的SHA-2)。我没有编写这个Hash函数,但我做了一个foor循环来测试它。我对C++不是很熟悉,所以我不知道为什么会出现以下情况。
当我执行这个程序时,计算时间越来越长。虽然我在最初的几秒钟内有大约10000个哈希,但几个小时后,我的电脑花了大约一分钟的时间来计算1000个哈希。。。有人能告诉我为什么以及如何"解决"这个问题吗?
这是相关的代码,我想:
int fortschritt = 0;
int prozent = 0;
string temp;
stringstream convert;
string loeschen;
for (int i = 1; i <= 4294967295; i++)
{
convert << i;
temp = convert.str();
loeschen = sha512(temp);
if (((int)(i/1000)) > fortschritt)
{
fortschritt = (int)(i/1000);
if (((int)(i*100)/4294967295) > prozent)
{
prozent = ((int)(i*100)/4294967295);
}
cout << fortschritt*1000 << " von 4294967295 - " << prozent << " %" << endl;
}
}
输出如下:
1000 von 4294967295 - 0 %
2000 von 4294967295 - 0 %
3000 von 4294967295 - 0 %
4000 von 4294967295 - 0 %
5000 von 4294967295 - 0 %
6000 von 4294967295 - 0 %
7000 von 4294967295 - 0 %
8000 von 4294967295 - 0 %
9000 von 4294967295 - 0 %
10000 von 4294967295 - 0 %
[...]
我认为这与我使用变量的方式有关,但我不确定,也不知道如何正确使用。如果这是一个愚蠢的问题,请原谅我,但它困扰了我一段时间。
提前感谢您的帮助:)
John
看起来convert
流在每次迭代中都会持续增长,每次都会附加新值。最简单的修复方法是在for循环中移动stringstream convert;
的声明,每次创建一个新声明。
进一步的优化当然是可能的,因为在主循环中进行大量迭代时,将数字转换为字符串的方式并不有效。
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 递归函数计算序列中的平方和(并输出过程)
- (C++)分析树以计算返回错误值的简单算术表达式
- 我的字符计数代码计算错误.为什么
- 在计算中使用二的幂有多有利可图
- 如何计算文件中的"columns"数?
- 计算排序向量的向量中唯一值的计数
- 如何使用 std::累积在 C++ 中计算总和立方体
- 使用Qt C++计算类似Git的SHA1哈希
- OpenCV C++.快速计算混淆矩阵
- cpp二进制搜索问题,计算给定数组中输入元素的出现次数
- C++如何计算用户输入的数字中的偶数位数
- 如何计算数据类型的范围,例如int
- 类似枚举的计算常量
- 计算每个节点的树高,帮助我解释这个代码解决方案
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 计算缩放多边形的比例,得到给定的多边形面积
- 在C++中如何在没有pow的情况下进行基础计算
- 计算平均值,不包括上次得分
- 如何在C++中准确地计算lops示例:计算哈希