gpt4 book ai didi

C++组合检查是否满足条件子集

转载 作者:太空宇宙 更新时间:2023-11-04 16:10:45 25 4
gpt4 key购买 nike

例如,我想确保 2/3 的值在给定的阈值内。下面的代码实现了这一点,但我想知道是否有更通用的方法。

struct foo {
int id;
float item1;
float item2;
float item3;
}

bool ConditionCheck(foo val1, foo val2, foo val3) {
int count = 0;
if (abs(val1.item1 - val2.item1) < val3.item1) {
count++;
}
if (abs(val1.item2 - val2.item2) < val3.item2) {
count++;
}
if (abs(val1.item3 - val2.item3) < val3.item3) {
count++;
}

if (count >= 2) {
return true;
}
return false;
}

问题源于自定义结构 else 将参数作为数组:

// assuming array holds: [id, item1, item2, item3]
bool ConditionCheck(float (&val1)[4], float (&val2)[4], float(&threshold)[4]) {
int count = 0;
for (unsigned int i = 1; i < 4; ++i) {
if (abs(val1[i] - val2[i]) < threshold[i]) {
count++;
}
}
if (count >= 2) {
return true;
}
return false;
}

最佳答案

您可以使用指向成员的指针数组:

bool ConditionCheck(foo val1, foo val2, foo val3) {
float foo::* ptrs[3] = { &foo::item1, &foo::item2, &foo::item3 };
return std::count_if( &ptrs[0],
&ptrs[3],
[&](float foo::* p)
{
return abs(val1.*p - val2.*p) < val3.*p;
}) >= 2;
}

关于C++组合检查是否满足条件子集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28973835/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com