位运算实现两个整数的加法运算

        在程序员面试宝典中,看到了这个知识点,在这里记录一下实现代码。

        

#include <iostream>

using namespace std;
int add(int a,int b)
{
    if(b==0) return a;
    int sum,carry;
    sum=a^b;
    carry=(a&b)<<1;
    return add(sum,carry);
}
int main()
{
    int a,b;
    cin>>a;
    cin>>b;
    cout<<add(a,b)<<endl;
    return 0;
}

        add函数中,其中a&b是取a与b相同位的一半,再左移一次<<之后就是a与b相同位的一半的两倍了,而a^b是取a和b的不同位,这个时候相当于不变,将其相加即为将a和b的相同位与不同位都加在一起,即实现了两个数相加,其中还考虑到了进位的情况。不过不足的是使用了循环,比较麻烦。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个C语言实现的例子。其中,LongInt是自定义的结构体类型,用来表示一个超长整数。该结构体类型包含一个char类型数组digits,数组元素用来存储整数各位数字,还包含一个int类型变量length,表示整数的有效位数。 ```c #include <stdio.h> #include <string.h> #include <stdlib.h> #define MAX_LENGTH 10001 // 数组最大长度 typedef struct LongInt { char digits[MAX_LENGTH]; // 存储数字的数组 int length; // 数字的有效位数 } LongInt; // 将字符串转换成LongInt类型 LongInt str2longint(char *str) { LongInt num; int len = strlen(str); for (int i = 0; i < len; i++) { num.digits[len-i-1] = str[i] - '0'; } num.length = len; return num; } // 将LongInt类型转换成字符串 char *longint2str(LongInt num) { char *str = (char*)malloc(sizeof(char)*(num.length+1)); for (int i = 0; i < num.length; i++) { str[i] = num.digits[num.length-i-1] + '0'; } str[num.length] = '\0'; return str; } // 高精度加法 LongInt add(LongInt num1, LongInt num2) { LongInt result = {.length = 0}; int carry = 0; // 进位标志 int len = (num1.length > num2.length) ? num1.length : num2.length; for (int i = 0; i < len; i++) { int sum = num1.digits[i] + num2.digits[i] + carry; carry = sum / 10; result.digits[i] = sum % 10; result.length++; } if (carry > 0) { // 处理最高位的进位 result.digits[result.length++] = carry; } return result; } int main() { char str1[MAX_LENGTH], str2[MAX_LENGTH]; printf("请输入第一个整数:"); scanf("%s", str1); printf("请输入第二个整数:"); scanf("%s", str2); LongInt num1 = str2longint(str1); LongInt num2 = str2longint(str2); LongInt result = add(num1, num2); char *str_result = longint2str(result); printf("结果为:%s\n", str_result); free(str_result); return 0; } ``` 这个程序首先读入两个字符串作为超长整数,调用str2longint函数将字符串转换成LongInt类型的数字,然后调用add函数进行加法运算,最后将结果转换成字符串并输出。其中,str2longint函数和longint2str函数用来将字符串和LongInt类型的数字互相转换,add函数用来进行高精度加法运算
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值