【问题标题】:How to find the position where two arrays have the same numbers? [closed]如何找到两个数组具有相同数字的位置? [关闭]
【发布时间】:2021-03-02 00:59:49
【问题描述】:

所以我试图用 C 语言编写一个猜测程序,用户必须输入 5 个数字,计算机生成 5 个随机数。我的用户输入数字的代码是这样的:

for (int i = 0; i < NUM_SIZE; ++i) {
        scanf("%d", &(userGuess[i]));
}

我想输出用户输入正确的位置,例如,如果用户输入 2 3 4 5 7 并且计算机的 5 随机数是 2 3 9 8 7 它会打印出 correct position(s): 0, 1, 4 这是我目前尝试过的,但它只能打印0, 1,当它尝试打印一个数字时,它会像我放的示例一样跳过它,它会打印 0、0 和一个长随机数。

for (int i = 0; i < NUM_SIZE; ++i){
        if (userGuess[i] == winNum[i]) {
            matchedPos[i] = i;
        }
}

【问题讨论】:

标签: arrays c compare


【解决方案1】:

问题是您从未为用户没有猜对的元素初始化matchedPos 的元素。你需要初始化所有的数组元素。

另外,将i 放入matchedPos 数组是没有意义的,因为它与数组索引相同。相反,根据猜测是否匹配分配01。然后你只需打印包含1 的索引。

int matchedPos[NUM_SIZE];

for (int i = 0; i < NUM_SIZE; i++) {
    matchedPos[i] = userGuess[i] == winNum[i];
}

printf("Correct guesses: ");
for (int i = 0; i < NUM_SIZE; i++) {
    if (matchedPos[i]) {
        printf("%d ", i);
    }
printf("\n");

【讨论】:

  • 非常感谢!我确实初始化了matchedPos[NUM_SIZE],但我没有在我的问题上显示它,我的错。这是我的打印语句错误 - 我只是打印数组中的元素,它打印位置不同的数字。我只需要在打印语句中使用逗号,但我已经知道该怎么做,再次感谢!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-09-28
  • 2017-12-17
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多