如何将C#中的Lambda表达式转换为C++
本文关键字:表达式 转换 C++ Lambda 中的 | 更新日期: 2023-09-27 18:24:06
我正在研究MinHash函数。我刚刚在C#中找到了一些代码,但我想用C++编写,因为我现有的代码都是用C++编写的。
我对lambda表达式和委托函数很困惑。
C#代码类似
public delegate uint Hash(int toHash);
private Hash[] hashFunctions;
// Public access to hash functions
public Hash[] HashFunctions
{
get { return hashFunctions; }
}
// Generates the Universal Random Hash functions
// http://en.wikipedia.org/wiki/Universal_hashing
private void GenerateHashFunctions(int u)
{
hashFunctions = new Hash[numHashFunctions];
// will get the same hash functions each time since the same random number seed is used
Random r = new Random(10);
for (int i = 0; i < numHashFunctions; i++)
{
uint a = 0;
// parameter a is an odd positive
while (a % 1 == 1 || a <= 0)
a = (uint)r.Next();
uint b = 0;
int maxb = 1 << u;
// parameter b must be greater than zero and less than universe size
while (b <= 0)
b = (uint)r.Next(maxb);
hashFunctions[i] = x => QHash(x, a, b, u);
}
}
// Universal hash function with two parameters a and b, and universe size in bits
private static uint QHash(int x, uint a, uint b, int u)
{
return (a * (uint)x + b) >> (32 - u);
}
我试着通过创建struct来翻译成C++,但我仍然不知道该如何处理这行
hashFunctions[i] = x => QHash(x, a, b, u);
到目前为止我有一个C++代码
struct Hash
{
// Universal hash function with two parameters a and b, and universe size in bits
unsigned int operator()(int toHash)
{
}
};
Hash* hashFunctions;
void GenerateHashFunctions(int u)
{
hashFunctions = new Hash[numHashFunction];
// will get the same hash functions each time since the same random number seed is used
for (int i = 0; i < numHashFunction; i++)
{
unsigned int a = 0;
// parameter a is an odd positive
while (a % 1 == 1 || a <= 0)
a = (unsigned int)rand()%10;
unsigned int b = 0;
int maxb = 1 << u;
// parameter b must be greater than zero and less than universe size
while (b <= 0)
b = (unsigned int)rand()%maxb;;
//hashFunctions[i] = x => QHash(x, a, b, u);
}
}
static unsigned QHash(int x,unsigned int a,unsigned int b,int u)
{
return (a * (unsigned int)x + b) >> (32 - u);
}
有人能给我一些建议吗?非常感谢
使用C++lambda表达式。
hashFunctions[i] = [=] (auto x) { return QHash(x, a, b, u); };
此外,请避免使用原始指针或数组。使用标准容器,例如
std::vector<std::function<uint (int)>>
此外,您不应该使用c样式的强制转换,如
(unsigned)(expression)
偏好
static_cast<unsigned>(expression)
编辑:下面是一个例子:
#include <vector>
#include <functional>
....
private:
using HashProvider = std::function<uint, (int)>;
auto GenerateHashFunctions(int u)
{
auto hashFunctions = std::vector<HashProvider>(numHashFunctions);
for (int i = 0; i < numHashFunctions; i++)
{
uint a = 0;
// parameter a is an odd positive
while (a % 1 == 1 || a <= 0) {
a = static_cast<uint>(r.Next());
}
uint b = 0;
int maxb = 1 << u;
// parameter b must be greater than zero and less than universe size
while (b <= 0) {
b = static_cast<uint>(r.Next(maxb));
}
hashFunctions.push_back([=](auto x) { return QHash(x, a, b, u); });
}
return hashFunctions;
}