C语言 交换算法之加减法,及溢出防范

交换算法之加减法

前面的章节中介绍了C语言交换算法中的临时变量法,算是比较基础的一种方法,但是使用定义了一个临时的变量来临时存储参数(指针)指向的内存地址中存储的值,这就需要一个额外的内存空间。

这里介绍的加减法并不需要增加一个额外的内存空间,但是需要溢出防范,具体的可参考下方的示例代码。

加减法示例代码

cpp 复制代码
bool __builtin_add_overflow(type a, type b, type *res)

该函数是一些GCC和Clang编译器内置的函数,可以用于检测整数的加法是否会导致溢出。

cpp 复制代码
#include <stdio.h>
#include <limits.h>
void swapNumber(int *a, int *b) {
    if( a == b ) return;
    int sum;
    if(__builtin_add_overflow(*a, *b, &sum)){
        printf("整数溢出!\n");
        return;
    }
    *a = *a + *b;
    *b = *a - *b;
    *a = *a - *b;
}
int main() {
    int x = 255;
    int y = 166;
    
    swapNumber(&x, &y);
    printf("加减法置换数值之后: x = %d, y = %d\n", x, y);
    return 0;
}

代码编译运行,得到输出:

cpp 复制代码
加减法置换数值之后: x = 166, y = 255

全栈开发助手原文:C语言 交换算法之加减法,及溢出防范

免责声明:内容仅供参考!

相关推荐
玫瑰花店19 小时前
万字C++中锁机制和内存序详解
开发语言·c++·算法
西幻凌云20 小时前
认识STL序列式容器——List
开发语言·c++·stl·list·序列式容器
~无忧花开~20 小时前
JavaScript实现PDF本地预览技巧
开发语言·前端·javascript
靠沿20 小时前
Java数据结构初阶——LinkedList
java·开发语言·数据结构
4***997420 小时前
Kotlin序列处理
android·开发语言·kotlin
froginwe1120 小时前
Scala 提取器(Extractor)
开发语言
t***D26420 小时前
Kotlin在服务端开发中的生态建设
android·开发语言·kotlin
Elias不吃糖21 小时前
LeetCode每日一练(209, 167)
数据结构·c++·算法·leetcode
Want59521 小时前
C/C++跳动的爱心②
c语言·开发语言·c++