编写函数 isReverse 的定义,其前两个参数是大小相等的整数数组,第三个参数是指示每个数组大小的整数。当且仅当一个数组与另一个数组相反时,该函数返回 true。 (这里的“反向”是指相同的元素但顺序相反。)
int isReverse(int array1[], int array2[], int size)
{
int i;
for (i=0;i<size;i++)
{
if(array1[i] == array2[size-1])
return 0;
else
return 1;
}
}
我不断收到错误消息。这是怎么回事。
最佳答案
当您从函数中的任何 block 内返回
时,函数执行将在那里结束,因此在您的情况下,即使数组的第一个元素匹配,您也会从函数返回,这是不正确的,你应该检查整个数组,然后最后从函数返回,检查下面的代码:
int isReverse(int array1[], int array2[], int size)
{
int i,status=1;
for (i=0;i<size;i++) //Size is the length of the array? if yes than you need -1 from it.
{
if(array1[i] == array2[size])
{
status=0;
--size;
}
else
return 1;
}
return status;
}
此外,size-1
不会更改变量 size 本身的值,因此 size
在整个循环中将保持不变,请使用 --size
这将减少实际变量的值,因此每次都会将其减一。
关于c - 写一个函数的定义,isReverse,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13854673/