1

我在生成整数数组时遇到问题。该程序用 -32429173 之类的数字填充数组的数百个单元格,而不是数字从 0 到 3 的 3 个单元格(例如)。也许问题出在分配内存的错误方式上?这是代码的错误部分。感谢您提前提供帮助。

int* generate()
    {

        int maxnumb;
        int i;
        scanf_s("%d",&size);    //size of an array
        scanf_s("%d",&maxnumb); //asks for maxnumb to fill the array with random numbers from 0 to maxnumb
        int* array=(int*)calloc(size,sizeof(int));
        for (i=0;i<size;i++)
          array[i] = rand() % maxnumb + 1;
        return array;
    }

这是完整的代码

#define _CRT_SECURE_NO_WARNINGS
#include<stdlib.h>
#include<stdio.h>
int size;

void swap(int* elem1,int* elem2) //swap elements
{
    int temp;
    temp=*elem1;
    *elem1=*elem2;
    *elem2=temp;
}
void bublesort(int* array,int size) //bublesort
{
    for (int j=1;j<size-1;++j)
    {
    for (int i=0;i<size-j;++i)
    {
        if ((array[i])>(array[i+1]))
        swap(&array[i],&array[i+1]);
    }

    }
}
int* enterHand() //handle entering
{

    int i;
    scanf_s("%d",&size);
    int* array=(int*)calloc(size,sizeof(int));
    for (i=0;i<size;i++)
    {
        scanf_s("%d",&array[i]);
    }
    return array;
}
int* enterFile() //entering from the file
{
    int i;
    int singlenumb;
    FILE* foo;
errno_t err;
    err=fopen_s(&foo,"input.txt","r");
    if( err == 0 )
  {
      printf( "The file 'input.txt' was opened\n" );
  }
  else
  {
      printf( "The file 'input.txt' was not opened\n" );
  }
    while (!feof(foo))  
    {
        fscanf_s(foo, "%d", &singlenumb);
        size++;
    }

    size-=1; 
    int* array=(int*)calloc(size,sizeof(int));
    rewind(foo);
    i=0;
    while (i!=size)  
    {

        fscanf_s(foo, "%d", &array[i]);
        i++;
    }
    fclose(foo);
    return array;
}
int* generate()
{

    int maxnumb;
    int i;
    scanf_s("%d",&size);    //size of an array
    scanf_s("%d",&maxnumb); //asks for maxnumb to fill the array with random numbers from 0 to maxnumb
    int* array=(int*)calloc(size,sizeof(int));
    for (i=0;i<size;i++)
      array[i] = rand() % maxnumb + 1;
    return array;
}
void putsFile(int* array, int size)
{
    int i=0;
    int k;
    FILE* fooo;
    fopen_s(&fooo,"output.txt","w");

    while (i!=size)
    {
        for (k=0; k<10; k++)
        {
            fprintf(fooo,"%d ", array[i]);
            i++;
        }
        fprintf(fooo,"\n");
    }
    fclose(fooo);
}
void printArray(int* array, int size)
{
    int i=0;
    int k;
    while (i!=size)
    {
        for (k=0; k<10; k++)
        {
            printf("%d ", array[i]);
            i++;
        }
        printf("\n");
    }
}
int main()
{
    int choice;
    int* pntr;
printf("choose a type of filling an array\n1 = handle filling\n2 = filling from the file\n3 = generating\nenter the number...\n");
scanf("%d", &choice);
switch (choice)
{
case 1: {pntr=enterHand();} break;
case 2: {pntr=enterFile();} break;
case 3: {pntr=generate();} break;
default: {pntr=NULL;} 
}
bublesort(pntr,size);
printf("choose a type of typing an array\n1 = console\n2 = file\nenter the number...\n");
scanf("%d", choice);
switch (choice)
{
case 1: {printArray(pntr, size);} break;
case 2: {putsFile(pntr, size);} break;
default: {printf("you entered the wrong number");} 
}
return 0;
}
4

3 回答 3

2

我认为你应该初始化你的 maxnumb

于 2013-10-27T16:56:08.653 回答
1

首先,这是一种更简单的填充数组的方法。

int randomGenerator(int min, int max);
int main(void)
{
    int array[100]//or any size
    for(i=0;i<sizeof(array)/sizeof(array[0]);i++)
    {
        array[i]=randomGenerator(1,3);//will issue only 1, 2 or three (as you requested)
    }                                 //change min and max for wider range
    return 0;
}

int randomGenerator(int min, int max)  //set the range of desired numbers in array
{
    int random=0, trying=0;

    trying = 1;         
    while(trying)
    {
        srand(clock());
        random = (rand()/32767.0)*(max+1);
        (random >= min) ? (trying = 0) : (trying = 1);
    }
    return random;
}  

您还可以做一些事情来使这个不重复,即这样您就不会得到两个黑桃 A。但是现在,你有更大的问题......

您的代码本来有太多问题需要构建。如果您发布一个小的、可构建的部分,带有特定的问题,它可以得到更好的解决。

于 2013-10-27T16:49:54.513 回答
0

和可以打印printArray()超出putsFile()数组大小。

int* enterFile()size在确定文件中的数量之前不设置为 0 int,因此使用可能意外的非零大小。

[编辑] Wellsize在全局未初始化空间中被隐式设置为 0。不过,建议在enterFile().

#if 0
  // The value of size is dependent on program history or uninitialized.
  while (!feof(foo)) {
    fscanf_s(foo, "%d", &singlenumb);
    size++;
  }
  size-=1; 
#else
  size = 0;  // Reset size to 0
  while (1 == fscanf_s(foo, "%d", &singlenumb)) {
    size++;
  }
#endif

建议:

void printArray(int* array, int size) {
// Also in void putsFile(int* array, int size)
  int i=0;
  while (i < size) {
    int k;
    for (k=0; k<10; k++) {
      printf("%d ", array[i]);
      i++;
      // Add
      if (i >= size) break;
    }
    printf("\n");
  }
}
于 2013-10-27T23:28:13.753 回答