我写了一个使用递归交换数组相邻元素的程序:
static arr_len;
void swap(int *a, int len)
{
int tmp;
if(len == 0 )
return;
else {
swap(a, len-1);
if(len == arr_len-1)
return;
else if (len > 1)
len++;
tmp = a[len];
a[len] = a[len-1];
a[len-1] = tmp;
}
}
int main()
{
int a[] = {1,2,3,4}, i;
arr_len = sizeof(a)/sizeof(a[0]);
swap(a, sizeof(a)/sizeof(a[0]));
for (i = 0; i< 4; i++)
printf("%d\n", a[i]);
}
我看到输出结果似乎是正确的:
2
1
4
3
但是当我向数组中添加更多元素时,问题就来了:
int a[] = {1,2,3,4,5,6}
我看到了以下输出:
2
1
4
5
6
3
*** stack smashing detected ***: ./a.out terminated
Aborted (core dumped)
!( n < 2 )
=>n > 1
- 0___________