比较c ++字符串打印中的两个整数数组

时间:2018-03-06 16:41:14

标签: c++ arrays compare

我正在尝试比较两个数组。如果它是真的,它需要打印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;
    }
}

2 个答案:

答案 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;适用于已排序的数组。