微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何找到两个数组具有相同数字的位置?

如何解决如何找到两个数组具有相同数字的位置?

所以我试图用 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;
        }
}

解决方法

问题在于,您从未为用户没有猜对的元素初始化 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");

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。