迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > C语言 >

在 C 语言中实现交换函数

作者:迹忆客 最近更新:2023/05/05 浏览次数:

本文将介绍几种在 C 语言中实现交换函数的方法。


使用临时变量在 C 语言中实现交换函数的方法

交换函数是对变量进行的典型操作。目前还没有像 C++ 那样的标准库函数提供这个函数,因为 C++ 有 std::swap 函数。在本文中,我们实现了针对积分值的 swap 函数;即大部分函数取 long int 类型的参数,但人们总是可以为不同类型定义多个原型,并使用宏扩展来保证通用功能。下面的例子演示了使用临时变量的交换函数。请注意,尽管这是最简单的实现,但在下面列出的其他版本中,这个版本相对来说是最快的(当使用编译器优化时)。

#include <stdio.h>
#include <stdlib.h>

void swap(long *x, long *y)
{
    long tmp = *x;
    *x = *y;
    *y = tmp;
}

int main(int argc, char *argv[])
{
    if (argc != 3) {
        printf("Usage: ./program first_number second_number/n");
        return 1;
    }

    long x = strtol(argv[1], NULL, 0);
    long y = strtol(argv[2], NULL, 0);

    printf("x:%ld, y:%ld\n", x, y);
    if (x != y)
        swap(&x, &y);
    printf("x:%ld, y:%ld\n\n", x, y);

    exit(EXIT_SUCCESS);
}

示例命令:

./program 123 432

输出:

x:123, y:432
x:432, y:123

使用算术运算来实现 C 语言中的交换函数

另外,也可以只用加法和减法运算实现交换函数。我们在函数中对传递的指针进行操作,从而直接修改参数值。在 main 函数中,在调用 swap 函数之前有一个 if 条件,以避免操作数相等时的调用。

#include <stdio.h>
#include <stdlib.h>

void swap(long *x, long *y)
{
    *x = *x + *y;
    *y = *x - *y;
    *x = *x - *y;
}

int main(int argc, char *argv[])
{
    if (argc != 3) {
        printf("Usage: ./program first_number second_number/n");
        return 1;
    }

    long x = strtol(argv[1], NULL, 0);
    long y = strtol(argv[2], NULL, 0);

    printf("x:%ld, y:%ld\n", x, y);
    if (x != y)
        swap(&x, &y);
    printf("x:%ld, y:%ld\n\n", x, y);

    exit(EXIT_SUCCESS);
}

在 C 语言中使用按位异或运算实现交换函数

交换函数最棘手也是略显复杂的实现方式就是使用按位异或操作。请注意,这个版本不像前面的例子那样需要第三个变量。首先,我们将给定整数的异或运算结果存储在它们的一个位置。然后,我们将存储的值(y)与另一个整数进行 XOR,并将结果存储在后者的位置上。最后,两个变量再进行一次异或运算,结果存储在第一个修改的变量中-本例中的 y。当编译时,这种实现涉及更多的机器代码指令,因此,产生了一个更多的计算密集型解决方案。

#include <stdio.h>
#include <stdlib.h>

void swap(long *x, long *y)
{
    *y = *x ^ *y;
    *x = *x ^ *y;
    *y = *x ^ *y;
}

int main(int argc, char *argv[])
{
    if (argc != 3) {
        printf("Usage: ./program first_number second_number/n");
        return 1;
    }

    long x = strtol(argv[1], NULL, 0);
    long y = strtol(argv[2], NULL, 0);

    printf("x:%ld, y:%ld\n", x, y);
    if (x != y)
        swap(&x, &y);
    printf("x:%ld, y:%ld\n\n", x, y);

    exit(EXIT_SUCCESS);
}

在 C 语言中使用按位异或操作和宏来实现交换函数

如前面的例子所示,XOR 交换函数也可以用类似函数的宏来实现。需要注意的是,需要检查两个操作数是否是同一个对象,否则,宏会将对象赋值为零,从而导致错误的输出。这个检查是用:条件来实现的,只有这样,我们才会执行类似前面实现的 XOR 交换算法。不过要注意,这个类似函数的宏只能处理整数值。

#include <stdio.h>
#include <stdlib.h>

#define XORSWAP(a, b)   ((&(a) == &(b)) ? (a) : ((a)^=(b),(b)^=(a),(a)^=(b)))

int main(int argc, char *argv[])
{
    if (argc != 3) {
        printf("Usage: ./program first_number second_number/n");
        return 1;
    }

    long x = strtol(argv[1], NULL, 0);
    long y = strtol(argv[2], NULL, 0);

    printf("x:%ld, y:%ld\n", x, y);
    XORSWAP(x, y);
    printf("x:%ld, y:%ld\n", x, y);

    exit(EXIT_SUCCESS);
}

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 C 语言中使用 typedef enum

发布时间:2023/05/07 浏览次数:181 分类:C语言

本文介绍了如何在 C 语言中使用 typedef enum。使用 enum 在 C 语言中定义命名整数常量 enum 关键字定义了一种叫做枚举的特殊类型。

C 语言中的静态变量

发布时间:2023/05/07 浏览次数:151 分类:C语言

本文介绍了如何在 C 语言中使用静态变量。在 C 语言中使用 static 变量在函数调用之间保存变量值

C 语言中生成随机数

发布时间:2023/05/07 浏览次数:64 分类:C语言

本文演示了如何在 C 语言中生成随机数。使用 rand 和 srand 函数在 C 语言中生成随机数

C 语言中的 i++ 与++i

发布时间:2023/05/07 浏览次数:83 分类:C语言

本文演示了如何在 C 语言中使用前缀增量与后缀增量运算符。C 语言中++i 和 i++ 记号的主要区别

C 语言中获取当前工作目录

发布时间:2023/05/07 浏览次数:182 分类:C语言

本文演示了如何在 C 语言中获取当前工作目录。使用 getcwd 函数获取当前工作目录的方法

C 语言中的位掩码

发布时间:2023/05/07 浏览次数:126 分类:C语言

本文介绍了如何在 C 语言中使用位掩码。使用 struct 关键字在 C 语言中定义位掩码数据

C 语言中的排序函数

发布时间:2023/05/07 浏览次数:181 分类:C语言

本文演示了如何在 C 语言中使用标准库排序函数。使用 qsort 函数对 C 语言中的整数数组进行排序

C 语言中的 extern 关键字

发布时间:2023/05/07 浏览次数:114 分类:C语言

本文介绍了如何在 C 语言中使用 extern 关键字。C 语言中使用 extern 关键字来声明一个在其他文件中定义的变量

C 语言中的 #ifndef

发布时间:2023/05/07 浏览次数:186 分类:C语言

本文介绍了如何在 C 语言中使用 ifndef。在 C 语言中使用 ifndef 保护头文件不被多次包含 C 语言中的头文件用于定义同名源文件中实现的函数的接口。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便