[英]comparing two integers arrays in c++ string printing
我正在尝试比较两个数组。如果它是真的,它需要打印字符串。因为它只需要打印一次但字符串打印了三次。我在两个数组中存储了三个值。你们能发现并告诉我出了什么问题。
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;
}
}
我猜您正在尝试进行词典比较。
很明显,如果您只想打印消息一次,则不应将打印语句放入循环中。
以下代码如何工作,我认为您希望您的代码工作。 比较的结果存储在变量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;
你可以简化:
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";
}
}
}
为了比较整个数组,您需要先对其进行排序。 “小于”和“大于”适用于排序数组。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.