我正在尝试比较两个数组。如果它是真的,它需要打印string.since它只需要打印一次但是字符串打印三次。其中我在两个数组中都存储了三个值。你们发现并告诉我出了什么问题。
for (int i = 0; i < n; i++)
{
if (l[i] == g[i])
{
cout << "equal" << endl;
}
else if (l[i] < g[i])
{
cout << "lesser" << endl;
}
else if (l[i] > g[i])
{
cout << "greater" << endl;
}
}
答案 0 :(得分:0)
我猜你正试图做lexicographic comparison。
很明显,如果你只打印一次消息,那么就不应该把打印语句放在循环中。
以下代码可以解释您希望代码如何工作的方式。比较结果存储在变量result
中,并且仅在循环结束后检查该变量。我使用break是因为一旦你发现一个不相等的项目就没有必要进行比较。
int result = 0;
for (int i = 0; i < n; i++)
{
if (l[i] < g[i])
{
result = -1;
break;
}
else if (l[i] > g[i])
{
result = +1;
break;
}
}
if (result == 0)
cout << "equal" << endl;
else if (result < 0)
cout << "lesser" << endl;
else
cout << "greater" << endl;
答案 1 :(得分:0)
你可以简化:
for (int i = 0; i < n; ++i)
{
const int l_value = l[i];
const int g_value = g[i];
if (l_value == g_value)
{
cout << "slot[" << i << "] is equal\n";
}
else
{
if (l_value < g_value)
{
cout << "slot[" << i << "] is less than\n";
}
else
{
cout << "slot[" << i << "] is greater than\n";
}
}
}
为了比较整个阵列,您需要先对其进行排序。 &#34;小于&#34;并且&#34;大于&#34;适用于已排序的数组。