我正在写一个二十一点程序中的交易功能有问题。任何人都可以看到发生了什么?当我尝试在main()中打印时,我遇到了分段错误。
干杯。
主要功能
int main(void)
{
int i, j, k, purse;
card deck[52];
card *head_d, *temp_d, *current_d = NULL, *last_d, *head_p, *temp_p, *current_p = NULL, *last_p;
make(deck); //CREATES THE DECK
shuffle(deck); //SHUFFLES THE DECK
deal(deck, head_d, current_d, head_p, current_p)
for(i = 0; i < DECK_SIZE; i++)
{
printf("%d: %d %c\n", i + 1, deck[i].face, deck[i].suit);
}
temp_p = head_p;
while(temp_p != NULL)
{
printf("%d %c\n", temp_p->face, temp_p->suit);
temp_p = temp_p->listp;
}
return(0);
}
FUNCTION deal()
void deal(card x[DECK_SIZE], card *head_d, card *current_d, card *head_p, card *current_p)
{
int i;
card *temp_p, *temp_d;
for(i = 0; i < 4; i++)
{
if( i % 2 == 0)
{
temp_p = (card *)malloc(sizeof(card));
temp_p->face = x[i].face;
temp_p->suit = x[i].suit;
if (current_p==NULL)
{
head_p=temp_p;
}
else
{
current_p->listp=temp_p;
}
current_p = temp_p;
temp_p->listp = NULL;
}
else
{
temp_d=(card *)malloc(sizeof(card));
temp_d->face = x[i].face;
temp_d->suit = x[i].suit;
if (current_d==NULL)
{
head_d=temp_d;
}
else
{
current_d->listp=temp_d;
}
current_d = temp_d;
temp_d->listp = NULL;
}
}
}
答案 0 :(得分:2)
问题是deal
函数的参数是 local ,这意味着当您在函数中更改它们的值时,调用函数时使用的变量将不会更改。您需要通过引用传递参数:
void deal(card x[DECK_SIZE], card **head_d, card **current_d, card **head_p, card **current_p);
do do。
*head_p=temp_p;
在设置变量的函数中。
呼叫
deal(deck, &head_d, ¤t_d, &head_p, ¤t_p);
答案 1 :(得分:0)
您的head_p
函数中有未初始化的指针变量main
。然而,您正在尝试读取head_p
所指向的数据。当然,你会得到段错误。