0

我在使用随机整数填充数组,然后让用户尝试猜测数组中的数字的猜谜游戏时遇到了一些麻烦。我相信我的大部分内容都是正确的,但程序不会超出“正在初始化幸运数字...”打印命令,让我检查我的功能是否正常工作。我相信问题在于我如何将数组传递给函数,或者我如何调用函数(也许在它们的原型中?)任何帮助将不胜感激。这是我的第一篇文章,所以如果我无法正确包含代码,我深表歉意。谢谢!

#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>

/*
This program is a lucky number guessing game. A series of unique, random numbers 
will be generated and stored in an array. Users will have up to three chances to
guess a number stored in the array.*/

//Function Prototypes
int fillArray (int,int []);
int searchArray (int, int []);
int printArray (int, int []);

int main(){
 const int MAX = 25;
 int iArray[MAX]={0};
 int count;

 printf("Initializing lucky numbers...");
 //printf("%d", iArray[0]);
 //for(count=0;count<MAX;count++){
   //printf("%d ",iArray[count]);
 //}//end for loop
 fillArray(MAX,iArray);
 //ONLY TO CHECK ARRAY CONTENTS
 //printf("%d",iArray[0]);
 //for(count=0;count<MAX;count++){
 //  printf("%d ",iArray[count]);
 //}//end for loop
 //CARRY ON WITH PROGRAM
 searchArray(MAX,iArray);

 getch();
 return 0;   
}

//Function Definitions

//Fill Array Function
int fillArray(int max,int Array[]){
    int i;
    int j;
    int uniqueFlag;
    int random;
    srand(time(NULL));

    for(i = 0; i < max; i++) {
     /* Assume things are unique... we'll reset this flag if not. */
     uniqueFlag = 1;
     do {
        random = (rand() % 101);
        /* This loop checks for uniqueness */
        for (j = 0; j < i && uniqueFlag == 1; j++) {
           if (Array[j] == random) {
              uniqueFlag = 0;
           }//end if statement
        }//end for loop
     } while (uniqueFlag != 1);
     Array[i] = random;
}//end while
//ONLY TO CHECK ARRAY CONTENTS
printf("%d",Array[0]);
printf("\n%d\n",Array[1]);
for(i=0;i<max;i++){
  printf("%d ",Array[i]);
}//end for
}//end function

//Search Array Function
int searchArray(int max, int Array[]){
    int i;
    int guessCounter=0;
    int iGuess;
    do{
       printf("Please guess a number between 0 and 100: ");
       scanf("%d",&iGuess); 
       for(i=0;i<max&&guessCounter<3;i++){
          if(Array[i] == iGuess){
              printf("Correct");
              guessCounter = 3;
              }//end if
          else{
               printf("%d is not one of the lucky numbers.\n",iGuess);
               guessCounter++;
               }//end else
               }//end for
    }while(guessCounter < 3); //end do-while loop
    if(guessCounter==3){
        printf("Sorry! You lose!\n");
        printArray(max, Array);
        }//end if
}//end function   

//Print Array Function
int printArray(int max, int Array[]){
    int i;
    printf("Array contents: ");
    for(i=0;i<max;i++){
       printf("%d ",Array[i]);
    }//end for
}//end function
4

3 回答 3

1

uniqueFlag needs to be reset whenever you pick a random number, not just at the start of the outer loop in fillArray.

于 2012-10-23T00:41:25.133 回答
1

感谢大家!对于任何检查或遇到类似问题的人,我已经包含了我的更正。我能够在一个名为 checkArray 的单独函数中检查唯一数字,并通过从 fillArray 函数返回一个指针以及其他一些(包含的)调整来解决我的 fillArray 问题。

#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>


//Function Prototypes
int fillArray (int, int []);
int checkArray (int, int, int []);
int searchArray (int, int []);
int printArray (int, int []);

int main(){
 const int MAX = 25;
 int iArray[MAX]={0};
 int count;

 printf("Initializing lucky numbers...\n");
 fillArray(MAX,iArray);
 searchArray(MAX,iArray);

 getch();
 return 0;   
}

//Function Definitions

//Fill Array Function
int fillArray(int max, int Array[]){
int number;
int i=0;
int uniqueFlag;
srand(time(NULL));

while(i<max){
     number = (rand() % 101);
     if(checkArray(max, number, Array)==0){ //passes to another function to check for uniqueness
          Array[i]=number;
          ++i;
     }//end if
}//end while
return *Array;
}//end function

//Check Array Function
int checkArray(int max, int number, int Array[]){
int i;
int uniqueFlag;
for(i=0;i<=max;i++){
     if(Array[i]==number){  //determines if random number has already been used in array
          uniqueFlag = 1;
          return uniqueFlag;
     }//end if
     else{
          uniqueFlag = 0;
     }//end else
}//end for
     return uniqueFlag;
}//end function

//Search Array Function
int searchArray(int max, int Array[]){
int i;
int x=0;
int guessCounter=0;
int iGuess;

while(x !=1 && guessCounter<3){
       printf("Please guess a number between 0 and 100: ");
       scanf("%d",&iGuess);
       for(i=0;i<max;i++){
            if(iGuess==Array[i]){
                 x = 1;
                 }//end if
       }//end for
       switch(x){
          case 1:
               printf("%d is one of the lucky numbers. Congratulations! You win!", iGuess);
               printArray(max, Array);
               getch();
               return 0;
          default:
               printf("%d is not one of the lucky numbers.\n",iGuess);
               ++guessCounter;
          }//end switch statement
          }//end while condition
if(guessCounter==3){   //condition limits to 3 guesses per run
          printf("Sorry! You lose!");
          printArray(max, Array);
          }//end if   
}//end function

//Print Array Function
int printArray(int max, int Array[]){
int i;
printf("\nArray contents: ");
for(i=0;i<max;i++){
   printf("%d ",Array[i]);
}//end for
//getch();
//return 0;
}//end function
于 2012-10-29T03:30:12.803 回答
0

第一眼看不searchArray出来有没有问题,应该简化一下。我建议将整个uniqueFlag部分移出它自己的功能,doesArrayContain也许?

于 2012-10-23T00:48:43.287 回答