我正在创建一个程序,该程序使用指向函数的指针,允许用户从2个选项中选择对整数数组执行:反向或随机。但是,程序在执行时不会产生任何输出。我哪里出错了?
void reverseArray(int arraySize, int a[]);
void randomiseArray(int arraySize, int a[]);
void printArray(int arraySize, int a[], void (*arrayFunction)(int arraySize, int a[]));
int main ()
{
srand(time(NULL));
int selection;
int myArray[] = {2,4,6,8,10,12,14,16,18,20};
printf("Enter 0 for reverse, 1 for randomise.\n");
scanf("%d",&selection);
if (selection == 0)
printArray(sizeof(myArray)/sizeof(myArray[0]),myArray,reverseArray);
else if (selection == 1)
printArray(sizeof(myArray)/sizeof(myArray[0]),myArray,randomiseArray);
else
printf("Please make a valid selection\n");
return 0;
}
void reverseArray(int arraySize, int a[])
{
int i,j=arraySize,swap=0;
for (i=0;i<arraySize/2;i++)
{
swap = a[i];
a[i] = a[j];
a[j] = swap;
--j;
}
}
void randomiseArray(int arraySize, int a[])
{
int i,j,swap;
for (i=0;i<arraySize;i++)
{
j = rand()%(i+1);
if (j!=i)
{
swap = a[i];
a[i] = a[j];
a[i] = swap;
}
}
}
void printArray(int arraySize, int a[], void (*arrayFunction)(int arraySize, int a[]))
{
arrayFunction(arraySize, a);
for (int i = 0; i < arraySize; i++)
{
printf("%d ", a[i]);
}
printf("\n");
}
用户通过键入0表示反向或1表示随机选择,选择他们想要执行的功能。根据该决定,调用printArray
函数并进行相应的选择。
reverseArray
只是一个通用交换函数,randomiseArray
使用Fisher-Yates混洗算法。
我假设我的错误来源于printArray
功能,但我无法纠正。
答案 0 :(得分:3)
两个错误
在reverseArray中,j
应该从arraysize - 1
开始,否则你将在数组末尾写一个元素
void reverseArray(int arraySize, int a[])
{
int i, j = arraySize - 1, swap = 0;
for (i = 0; i<arraySize / 2; i++)
{
swap = a[i];
a[i] = a[j];
a[j] = swap;
--j;
}
}
在randomizearray()
中,您分配给a[i]
两次,而不是使用a[j]
进行最终分配。
void randomiseArray(int arraySize, int a[])
{
int i, j, swap;
for (i = 0; i<arraySize; i++)
{
j = rand() % (i + 1);
printf("%d %d\n", i, j);
if (j != i)
{
swap = a[i];
a[i] = a[j];
a[j] = swap;
}
}
}
第一个错误在反转时导致未定义的行为,第二个错误导致数组保持不变。除此之外,函数指针设置正常并且工作正常。
答案 1 :(得分:0)
在reverseArray()中,你的索引j
超出了范围,应该是j=arraySize-1
除此之外,它对我有用。
答案 2 :(得分:0)
您正在数组的边界外访问,导致UB,在这种情况下“无输出”:
在reverseArray
中,您必须初始化j=arraySize-1
。如果没有-1
,你就会超出界限。