如何解决如何找到两个数组具有相同数字的位置?
所以我试图用 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
数组是没有意义的,因为它与数组索引相同。相反,根据猜测是否匹配分配 0
或 1
。然后您只需打印包含 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 举报,一经查实,本站将立刻删除。