我试图使函数有一个循环,检查由布尔变量组成的数组的每个成员,并在找到第一个"true"值时退出。
这就是我现在拥有的:
bool solids[50];
int a,i;
//"equality" is a function that checks the equality between "a" and a defined value
solids[0] = equality(a,&value_1);
solids[1] = equality(a,&value_1);
solids[2] = equality(a,&value_1);
solids[3] = equality(a,&value_1);
for (i = 0; solids[i] != true; i++)
{
[...]
}
但是我不知道,我应该把什么放入循环中?
我的尝试是
for (i = 0; i <= 50; i++)
{
if (solids[i] == true)
{
return true;
break;
} else {
return false;
}
}
,应该在第一个发现为真后返回true
,如果数组没有具有true
值的成员则返回false
,但它似乎在代码中不起作用。
错了吗?如果有,是什么问题?
p。:我可以用计数器计算true
s的数量,但这不是问题的最佳解决方案,因为我只是寻找第一个true
值,因此,程序不必检查所有50个成员。Needley计算一下,这意味着要解决多少不必要的步骤。
下面是@chris:
建议的std::find()的一个简短示例bool find_element_in_array() {
bool solids[50];
int length;
/* ... do many operations, and keep length as the size of values inserted in solids */
bool* location = std::find(solids, length, true);
// if element is found return true
if (location != solids + length)
return true;
// else return false
return false;
}
一旦您正确设置了实体(看起来您当前将每个值设置为相同的东西),您可以创建一个循环,在第一个true上退出,如下所示:
for (i = 0; i < 50; i++)
{
if (solids[i] == true)
{
return true;
}
}
return false;
我也只是将i
的声明移动到for
循环体中,因为它不在外部使用,但上面回答了您的问题。
return
立即退出函数,因此不需要在之后的循环中执行break
。
如果在搜索之后立即退出函数就足够了,您应该这样写:
for (int i = 0; i < 50; i++) {
if (solids[i]) return true;
}
return false;
如果需要在同一函数中使用搜索结果,请使用附加变量:
bool found = false;
for (int = 0; i < 50; i++) {
if (solids[i]) {
bool = true;
break;
}
}
if (found) { ...