0

我必须编写一个程序来存储和打印内存中的整数。我必须使用重新分配。基本上,该程序为 2 个整数分配大小。当输入给出 2 个 int 时,它应该为 1 个 int 重新分配空间并打印出 double。接下来,当输入给定 3 个 int 时,它应该为 int 再分配 2 个空间并打印出 double.. 等等..

Test cases:

input file in.0:
------
4
------

expected output:
------
4
------

=================================================

input file in.1:
------
4 5
------

expected output:
------
4
5
double
------

==================================================

input file in.2:
------
4 5 3
------

expected output:
------
4
5
double
3
double
------

===================================================

input file in.3:
------
4 5 3 2 9
------

expected output:
------
4
5
double
3
double
2
9
double

我写了这个程序,但它没有正确分配内存。有人可以指导我的写作方向吗?

int main(void)
{
    int c;

    int digit;
    int count = 0;
    int d_size = 1;
    int init_size = 2;
    int *p = (int *) malloc(sizeof(int) * init_size);

    while((c = scanf("%i", &digit)) != EOF)
    {
        if (c == 1)
        {
            *(p+count) = digit;
            count++;
        }
        else
        {
            printf("not valid");
        }

        printf("%i\n", digit);

        if (count >= 2)
        {
            printf("double\n");
            p = (int *) realloc(p, sizeof(int) * d_size);
            d_size = d_size * 2;
        }

    }
4

1 回答 1

4

init_size是 2,但你d_size是 1。首先,使d_size等于init_size。其次,您需要d_size = d_size * 2在 the 之前执行此操作,realloc这样您实际上会增加大小。


旁注:realloc如果内存不足,将失败。如果你写:

p = realloc(p, ...);

如果失败,您将丢失之前分配的内存。你应该总是这样使用realloc

enlarged = realloc(p, ...);
if (enlarged == NULL)
    // handle error
else
    p = enlarged;

旁注 2:您最终可能会更改指针的类型。最好不要重复。代替

int *p;
p = (int *)malloc(sizeof(int) * count);

写:

int *p;
p = malloc(sizeof(*p) * count);
于 2012-06-27T18:58:17.737 回答