数据结构学习 jz65 不用加减乘除做加法

关键词:位运算

因为没怎么接触位运算,所以看了答案才做出来的。

题目:

思路:

把结果分为无进位和 和 进位。

无进位和:

可以用异或计算(结果放在dataA)

dataA^=dataB;

进位:

可以用与计算,为了给下一轮计算,计算之后要左移一位。

int c=(unsigned int)(dataA&dataB)<<1;//与 进位

比如 0 1 1

        0 1 0

与    0 1 0

左移1 0 0

为什么要while循环?

因为AB异或的结果是无进位和,进位的部分还没算呢。所以得再加一次,再加一次就会有可能又有进位了,所以得循环加,把上一轮的进位结果加进来。直到没有进位结果为止。

 复杂度计算:

时间复杂度O(1)

空间复杂度O(1)

代码:

class Solution {
public:
    int encryptionCalculate(int dataA, int dataB) {
        while(dataB!=0)
        {
            int c=(unsigned int)(dataA&dataB)<<1;//与 进位
            dataA^=dataB;//异或 无进位和
            dataB=c;
        }
        return dataA;
    }
};

 

以下是汇编语言代码实现大数计算加减乘除的示例: 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值