arrays - 使用递归交换数组中的相邻元素

标签 arrays c linux recursion swap

我编写了一个程序来使用递归交换数组的相邻元素:

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)

最佳答案

对于初学者来说,使用全局变量 arr_len 是个坏主意。

在任何情况下你的函数都是无效的。考虑一个简化的例子,当数组只包含 1 或 2 个元素时。当数组包含一个元素时,您将在该语句中使用等于 len 的无效索引访问数组以外的内存

tmp = a[len];

这个函数看起来要简单得多。例如

void swap( int *a, size_t n )
{
    if ( !( n < 2 ) )
    {
        int tmp = a[0];
        a[0] = a[1];
        a[1] = tmp;
        swap( a + 2, n - 2 );
    }
}    

关于arrays - 使用递归交换数组中的相邻元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69408949/

相关文章:

javascript - 在不触发 ng-change 的情况下设置文本输入字段的初始值

c++ - 在 Windows 内核设备驱动程序中使用 fprintf

c - 从 memcpy 返回到双变量

Linux : How can I print line number and column number when values do not match for tab separated files using AWK in linux

java - 从 int 转换为 Integer 并排序

php - Array PHP,检查是否存在多个元素到另一个数组

javascript - Jquery - 从选择框进行数组操作

c - 关于 LINUX 中的段错误

linux - 未调用 MCP23017 I2C 设备驱动程序探测函数

linux - Ncat 连接并立即在 Windows 上执行命令