我对刽子手游戏的两个字符串的比较不能正常工作

时间:2014-01-08 09:19:52

标签: c strcmp strlen

我一直在为一门课程做一个刽子手游戏而且我差不多完成了。但是,我偶然发现了一个我似乎无法解决的问题。

首先,计算机从文本文件中选择一个随机单词,取出该单词的长度,并用该长度创建原始单词的掩码副本。然后游戏开始。玩家输入字母,如果单词在他/她失败六次之前完成,他就赢了。否则,他/她松了。我认为我的代码问题是当我创建计算机选择的单词的掩码时,但我不确定。

如果我运行该程序,它看起来像这样:

选择单词:strand (首先控制计算机选择的单词)

选择单词:strand (第二个控件,查看相同的单词是否从函数复制到主要字符串中)

选择单词:怪物 (由free()函数打印。出于某种原因,它只有一个单词)

选择单词:strand (在复制单词的长度之前完成第三个控制,以查看是否复制了正确的单词,它是什么)

Wordlenght:6 (控制以查看长度是否与单词相符,

面具:_ _ _ _ _ _ N (忽略下划线之间的空格,它们只是为了让它更容易看到。这就是我认为问题所在的地方,因为最后添加了额外的字符,在这种情况下为“N”。下划线的数量与字母的数量相匹配,这是好的)

面具:_ _ _ _ _ _ N (由第二个free()函数打印)

然后实际游戏开始。其他一切正常(如果玩家中止或失败,如果玩家想要或不想再玩)。我检查了strcmp()函数中的实际int resultat (char* word, char* mask, int count)是否有效,确实如此。所以故障与被比较的字符串有关。我想当我用strlen()得到所选单词的长度时。当我得到长度时,我减去一个因为否则我会得到一个太长的长度(例如,纸张会给出6的长度,但是当我减去一个时我会得到5)。

如果有人可以帮助我或者给我一些提示,我将非常感激!

#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
#include<string.h>
#include<time.h>

#define MAX_WORD_LEN 20

char* datorns_val();
int ordlengd(char* word);
char* datorns_val_mask(char* word, int len);
int spel(char* word, char* mask, int len, int count, int result);
int resultat (char* word, char* mask, int count);
char get_user_choice();
void hangman(int count, int result);

const int MAX_GUESS = 6;
const char ABORT_CH = '0';
const int LOOSE = 0;
const int WIN = 1;
const int ABORTED = 2;

/************************************************************
 *
 *                       MAIN
 *
 *
 ************************************************************/

int main ()
{
    char word[MAX_WORD_LEN];
    char mask[MAX_WORD_LEN];
    int ch;
    int len;
    int result;
    int count;

    /*   -------------------- Programstart  -----------------*/

    srand(time(NULL));

    while (true) 
    { 
          result = 5;
          count = 0; 
          strcpy(word,datorns_val());
          printf("Valt ord 2: %s", word);
          free(datorns_val());
          len = ordlengd(word);
          strcpy(mask,datorns_val_mask(word,len));
          printf("\nMask 2: %s <-----", mask);
          free(datorns_val_mask(word,len));

          printf( "\nV\x84lkommen till HANGMAN 2014!\n");
          printf( "Du har %d gissningar p\x86 dig (avbryt med 0)\n", MAX_GUESS );
          printf( "Datorn har nu valt ett ord p\x86 %d bokst\x84ver\n", len );

          /* GAME MAIN LOOP */

          while (count < 6)
          {
                count=spel(word,mask,len,count,result);
                result=resultat(word,mask,count);
                hangman(count,result);
          }

          /* END MAIN GAME LOOP */

          if( result == WIN )
          {
              printf("\nGrattis du vann!\n");
          }
          else if( result == LOOSE )
          {
              printf("\nTyv\x84rr du f\x94rlorade! Ordet var: %s\n", word);
          }
          else
          {
              printf("Avbrutet\n");
          }     
          printf("Vill du spela igen? (j/n)");
          ch = get_user_choice();
          if (ch == 'n' || ch == 'N')
          {
                 break;
          }
    }
}
/***********************************************************
 *
 *  ---------        Funktionsdefinitioner ----------------
 *
 ***********************************************************/
char get_user_choice()
{
                  char tkn;
                  scanf(" %c", &tkn);
                  return tkn;
}
char* datorns_val()
{
    char ordlista[20];
    char* valt_ord = malloc(20);
    int random;
    int raknare = 0;
    random = rand()%4+1;
    FILE *ptr_file;
    ptr_file =fopen("hangman.dat","r");
    if (!ptr_file)
    {
                  printf("Filen kunde inte öppnas!");
    }
    while (fgets(ordlista,20, ptr_file)!= NULL)
    {
          if (raknare == random)
          {
                      strcpy(valt_ord, ordlista);
                      break;
          }
          raknare=raknare+1;
    }
    printf("Valt ord 1: %s",valt_ord);
    fclose(ptr_file);
    return valt_ord;
}
int ordlengd(char* word)
{
    printf("Valt ord 3: %s", word);
    int ordlengd;
    ordlengd=strlen(word)-1;
    printf("Ordlengd 1: %i", ordlengd);
    return ordlengd;
}
char* datorns_val_mask(char* word, int len)
{
     int j;
     char* gissning = malloc(20);
     for (j=0; j<len; j++)
     {
         gissning[j]='_';
     }
     printf("\nMask 1: %s <----", gissning);
     return gissning;
}
int spel(char* word, char* mask, int len, int count, int result)
{
     int j;
     char bokstav;
     int ratt = 0;
     printf("\nSkriv en bokstav: ");
     scanf(" %c", &bokstav);
     for(j=0; j<len; j++)
     {
              if(bokstav==word[j])
              {
                                  mask[j]=bokstav;
                                  ratt = 1;
              }
              else if(bokstav=='0')
              {
                   count = 7;
                   return count;
              }

     }
     if (ratt == 0)
     {
                    printf("\nBokstaven finns inte i ordet!\n");
                    count=count+1;
     }
     printf("Antal fel: %i\n\n", count);
     ratt = 0;
     for (j=0; j<len; j++)
     {
         printf("%c", mask[j]);
         printf(" ");
     }
     return count;
}
void hangman(int count, int result)
{
     const char* str[20]; 
     int j;   
     str[0]="\n_______ \n";
     str[1]="  | \n";
     str[2]="  O \n";
     str[3]="//|\\\\\n";
     str[4]="  | \n";
     str[5]="// \\\\\n";

     if(result != ABORTED)
     {
               for (j=0; j<count; j++)
               {
                   printf("%s", str[j]);
               }
     }
}
int resultat (char* word, char* mask, int count)
{
    char* a = "Hej";
    char* b = "Hej";
       if (count == 6)
       {
            return LOOSE;
       }
       else if (count < 6 && strcmp(mask,word) == 0)
       {
            return WIN;
       }
       else if (count == 7)
       {
           return ABORTED;
       }
}

1 个答案:

答案 0 :(得分:0)

代码周围有一些东西:

1)第一个free()调用毫无意义:

free(datorns_val());

这为字符串保留内存并删除它而不使用它。所以摆脱它。

2)使用fgets()从文件中读取字符串还将行末尾的'\ n'字符存储到字符串中,因此您必须将其删除。作为提示,我使用了这句话:

while(fscanf(ptr_file,"%s", ordlista) >0)

不存储'\ n'字符。

3)在ordlengd(char * word)函数中,你有一个额外字符的问题(上面提到的'\ n')所以长度与strlen()返回的长度相同,而不是

strlen(word) - 1 
你写过了。

4)你已经考虑了另一个条件来结束main函数的while循环。我建议添加

else return 5;

在resultat()函数的末尾,并检查此值和主函数的while循环

while (count < 6 && result == 5)

希望有所帮助