JZ65 不用加减乘除做加法(&,^)

一:题目

二:思路

三:代码

int Add(int num1, int num2 ) 
{
    //a+b = (a ^ b)+(a&b<<1)
    //num2 ==0 时表示没有进位了
    while(num2)
    {
        int tmp = num1;
        //得到不进位的数据
        num1 = num2 ^ tmp;
        //得到进位的数据
        num2 = (tmp&num2)<<1;
    }
    return num1;
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是汇编语言代码实现大数计算加减乘除的示例: 1. 大数加法代码: ```assembly ; 大数加法 ; 输入:两个大数 num1 和 num2,存放在数组中,数组长度为 n ; 输出:结果存放在 num1 中,如果结果超出数组长度则返回错误 ; 使用寄存器:eax, ebx, ecx, edx addition: push ebp mov ebp, esp push ebx push ecx push edx mov ecx, [ebp + 12] ; 数组长度 n mov ebx, [ebp + 8] ; 数组 num1 mov edx, [ebp + 16] ; 数组 num2 xor eax, eax ; 清空进位 add_loop: cmp ecx, 0 ; 判断是否已经处理完所有位数 jz end_addition mov al, [ebx + ecx - 1] ; 取出 num1 的当前位 add al, [edx + ecx - 1] ; 加上 num2 的当前位 add al, ah ; 加上上一位的进位 mov [ebx + ecx - 1], al ; 存回 num1 的当前位 jnc add_next ; 判断是否需要进位 inc ah ; 进位 add_next: dec ecx ; 处理下一位 jmp add_loop end_addition: mov esp, ebp pop edx pop ecx pop ebx pop ebp ret ``` 2. 大数减法代码: ```assembly ; 大数减法 ; 输入:两个大数 num1 和 num2,存放在数组中,数组长度为 n ; 输出:结果存放在 num1 中,如果 num1 < num2 则返回错误 ; 使用寄存器:eax, ebx, ecx, edx subtraction: push ebp mov ebp, esp push ebx push ecx push edx mov ecx, [ebp + 12] ; 数组长度 n mov ebx, [ebp + 8] ; 数组 num1 mov edx, [ebp + 16] ; 数组 num2 xor eax, eax ; 清空借位 sub_loop: cmp ecx, 0 ; 判断是否已经处理完所有位数 jz end_subtraction mov al, [ebx + ecx - 1] ; 取出 num1 的当前位 sub al, [edx + ecx - 1] ; 减去 num2 的当前位 sub al, ah ; 减去上一位的借位 mov [ebx + ecx - 1], al ; 存回 num1 的当前位 jnc sub_next ; 判断是否需要借位 inc ah ; 借位 sub_next: dec ecx ; 处理下一位 jmp sub_loop end_subtraction: mov esp, ebp pop edx pop ecx pop ebx pop ebp ret ``` 3. 大数乘法代码: ```assembly ; 大数乘法 ; 输入:两个大数 num1 和 num2,存放在数组中,数组长度为 n ; 输出:结果存放在 num1 中,如果结果超出数组长度则返回错误 ; 使用寄存器:eax, ebx, ecx, edx multiplication: push ebp mov ebp, esp push ebx push ecx push edx mov ecx, [ebp + 12] ; 数组长度 n mov ebx, [ebp + 8] ; 数组 num1 mov edx, [ebp + 16] ; 数组 num2 xor eax, eax ; 清空进位 mul_loop: cmp ecx, 0 ; 判断是否已经处理完所有位数 jz end_multiplication xor edx, edx ; 清空余数 mov al, [edx + ecx - 1] ; 取出 num2 的当前位 mul_byte: cmp edx, 0 ; 判断是否已经处理完当前位的所有进位 jz next_digit add [ebx + ecx + edx - 1], al ; 加上当前位的进位 jnc next_digit ; 判断是否需要继续进位 inc edx ; 进位 next_digit: dec edx ; 处理下一位 shr al, 1 ; 右移一位 jnz mul_byte ; 判断是否已经处理完所有位数 dec ecx ; 处理下一位 jmp mul_loop end_multiplication: mov esp, ebp pop edx pop ecx pop ebx pop ebp ret ``` 4. 大数除法代码: ```assembly ; 大数除法 ; 输入:两个大数 num1 和 num2,存放在数组中,数组长度为 n ; 输出:商存放在 num1 中,余数存放在 num2 中,如果 num2 = 0 则返回错误 ; 使用寄存器:eax, ebx, ecx, edx division: push ebp mov ebp, esp push ebx push ecx push edx mov ecx, [ebp + 12] ; 数组长度 n mov ebx, [ebp + 8] ; 数组 num1 mov edx, [ebp + 16] ; 数组 num2 xor eax, eax ; 清空余数 xor ebx, ebx ; 清空商 mov [ebp - 4], eax ; 初始化计数器 div_loop: cmp ecx, 0 ; 判断是否已经处理完所有位数 jz end_division mov al, [ebx + ecx - 1] ; 取出 num1 的当前位 mov ah, 0 ; 清空高位 div [edx + ecx - 1] ; 除以 num2 的当前位 mov [ebx + ecx - 1], al ; 存回商的当前位 inc [ebp - 4] ; 计数器加一 cmp edx, 0 ; 判断余数是否为零 jz zero_remainder dec [ebp - 4] ; 计数器减一 mov [edx + ecx - 1], dl ; 存回余数的当前位 zero_remainder: dec ecx ; 处理下一位 jmp div_loop end_division: mov esp, ebp pop edx pop ecx pop ebx pop ebp ret ``` 以上是汇编语言实现大数计算加减乘除的示例,代码可能存在一些细节问题,仅供参考。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

玖剹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值