gpt4 book ai didi

c - 数组显示其指针而不是其值

转载 作者:行者123 更新时间:2023-11-30 19:21:14 26 4
gpt4 key购买 nike

我遇到了一些麻烦,不幸的是我仍在学习这种语言的细节。

我有以下代码

#define SIZE 5
typedef struct
{
int start;
int end;
int nElements;
int vetor[SIZE];
} TSTACK;

我尝试使用以下函数在其数组中插入值:

void Push(TSTACK *s, int elementInsert)
{
if(IsFull(s))
{
printf("%s\n", "# ERROR: full.");
}
else
{
s->end++;
if(s->end == SIZE)
{
s->end = 0;
}

s->vetor[s->end] = elementInsert;
s->nElements++;
}
}

我使用以下函数来显示元素:

void Display(TSTACK *s)
{
int i;
if (isEmpty(s))
{
printf("%s\n", "# ERROR: empty");
}
else
{
for (i = 0; i < s->nElements; i++)
{
printf ("value: %d\n", s->vetor[i]);
}
}
}

我的问题是,当我添加不同数量的元素时,我不会得到相同的结果,当我插入 5 个元素时,显示函数会正确显示所有元素,但当我插入少于 5 个元素时,会出现第一个项目作为它的指针:

以下主要结果在4201166,3,5,7

int main(void)
{
TSTACK test;

test.start = 1;
test.end = 0;
test.nElements = 0;

Push(&test, 3);
Push(&test, 5);
Push(&test, 7);
Push(&test, 3);

Display(&test);
}

以下主要结果为5,3,5,7,3

int main(void)
{
TSTACK test;

test.start = 1;
test.end = 0;
test.nElements = 0;

Push(&test, 3);
Push(&test, 5);
Push(&test, 7);
Push(&test, 3);
Push(&test, 5);

Display(&test);
}

有人可以告诉我我错在哪里吗?

最佳答案

当你“插入”一个元素时,你可以在

s->vetor[s->end]

但在执行此操作之前,您增加 s->end,因此第一个元素将位于 s->vetor[1] 。由于第一个元素 (s->vetor[0]) 未初始化,因此您将在其中获得一个随机值。这就是在四值插入中首先出现一个奇怪值的原因。

当您插入第五个值时,您将检查 s->end == SIZE 并将 s->end 设置为零,因此最后一个值在这种情况下,最终将出现在数组的第一位。

解决上述两个问题的解决方案是在将值分配给数组后增加 s->end

关于c - 数组显示其指针而不是其值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20353801/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com