0

我的主要默认设置是分析的逻辑。有什么要求。分析函数中的处理算法是练习的主要兴趣。

我需要比较被调用的玩家命题essai[]ref[]. ref[]是由随机函数生成的 4 位数字。一个数字被算作“正好在正确的地方”,不能算作“正确的数字在错误的地方”。示例:ref[] = {1, 2, 3, 4}essai[] = {1, 5, 7, 3}。它将在“完全正确的地方”计为 1 个数字,在“错误的地方”计为 0 个数字。不能超过一次。其他方式也一样。我从正确的地方开始,如果有的话,我用 -1 替换两个essai[]数字ref[]。我对“错误位置的正确号码”做了同样的事情。

到目前为止,这是我的代码:

void analyse(int ref[], int essai[]) {
int i, j, o, RefTmp[4], NbPos, NbChif;

for(i = 0; i < 4; i++){
  RefTmp[i] = ref[i];
}

for (j = 0; j < 4; j++) { // [1] = 5 : [1] = 2
    for (o = 0; o < 4; o++) {
        if (RefTmp[j] == essai[o]) {
            if (j == o) {
                ++NbPos;
                RefTmp[j] = essai[o] = -1;
                printf("One number in the right place\n");
                break;
            }
            else {
                ++NbChif;
                RefTmp[j] = essai[o] = -1;
                printf("One number in the wrong place\n");
                break;
            }
        }
    }
}
}

我的理解是我需要进行 2 个for循环来比较两个数组,但是当有多个“错误的正确数字”时(例如),循环也会打印多次。它只能打印一次。我做了一个RefTmp[],这样真实的东西ref[]就不会在这个过程中被破坏。

4

1 回答 1

0

在考虑处理“正确编号错误位置”实例之前,您应该找到并“擦除”所有“正确编号正确位置”实例(只需要一个循环)。

于 2021-12-28T18:46:17.280 回答