大数相加和大数相减

1,大数相减

大整数相减。有两个非常大的整数,因为太大所以用数组保存,计算大数相减的结果。
减法操作是需要提前判断出大一点的那个数的。

vector<string> bigint_subtraction(vector<int>& nums, int target) {
    vector<int> A = {1,3,4,6,8};
    vector<int> B = {1,3,4,6,9};
    //将大的值变成A,小一些的值变成B
    int asize = A.size(),bsize = B.size();
    bool b_above_a = false;
    if (bsize==asize) {
        for (int i=0;i<asize;i++) {
            if (B[i]>A[i]) {
                b_above_a = true;
                break;
            }
        }
    }
    if (b_above_a || bsize>asize) {
        vector<int> temp = B;
        B = A;
        A = temp;
        b_above_a = true;
    }
    //用大数减去小数,使用借位符查看是不是需要借位
    int jieweifu = 0;
    vector<int> result;
    int i=A.size()-1,j=B.size()-1;
    //A中的数减去B中的数
    for (;j>=0;i--,j--) {
        int num_a = A[i] - jieweifu;
        int diff = num_a - B[j];
        if (diff < 0) {
            jieweifu = 1;
            diff += 10;
        }
        else
            jieweifu = 0;
        result.push_back(diff);
    }
    //若A中的数还有,则继续跟进位符做判断
    for (;i>=0;i--) {
        int diff = A[i] - jieweifu;
        if (diff < 0) {
            jieweifu = 1;
            diff += 10;
        }
        else
            jieweifu = 0;
        result.push_back(diff);
    }
    //将结果数组末尾的0去掉
    for (int i=result.size()-1;i>0;i--) {
        if (result[i]==0) 
            result.pop_back();
        else
            break;
    }
    //将结果数组反转,并根据正负加上符号;
    vector<string> new_result;
    if (b_above_a) 
        new_result.push_back("-");
    for (int i=result.size()-1;i>=0;i--) 
        new_result.push_back(to_string(result[i])); 
    cout<<"new_result:";
    for (int i=0;i<new_result.size();i++) 
        cout<<new_result[i]; 
    return new_result;
}

2,大数相加

两个很大很大的正整数,将之保存在数组中,求两数相加之和
解题思路:解题思路:A,B和进位符相加,将余数保存起来,并更新进位符;将剩余的数组转变成A,将A继续与进位符一起遍历,并将结果数据保存起来。

vector<int> bignum_add() {
    //大数相加
    vector<int> A = {3,4,6,8};
    vector<int> B = {6,3,4,6,9};
    //大数和进位符相加
    int jinweifu = 0;
    vector<int> result;
    int i=A.size()-1,j=B.size()-1,remainder;
    for (;j>=0 && i>=0;i--,j--) {
        int num_sum = A[i] + B[j] + jinweifu;
        remainder = num_sum%10;
        jinweifu = num_sum>=10?1:0;
        result.push_back(remainder);
    }
    //默认A中数据比较大,若B的数据比较大,就把B赋值给A,然后A与进位符一起操作后加入到result     
    if (j>0) {
        i=j;
        A=B;
    }          
    for (;i>=0;i--) {
        int num_sum = A[i] + jinweifu;
        remainder = num_sum%10;
        jinweifu = num_sum>=10?1:0;
        result.push_back(remainder);
    }       
    //若最后一位计算完之后还有数据就在末尾加1
    if (jinweifu>0) 
        result.push_back(1);
    //将结果数据反转
    vector<int> new_result;
    for (int i=result.size()-1;i>=0;i--) 
        new_result.push_back(result[i]); 
    cout<<"new_result:";
    for (int i=0;i<new_result.size();i++) 
        cout<<new_result[i]; 
    return new_result;
}
当然可以,下面是一个简单的Java程序,用于计算两个大数的加法和减法。这个程序使用字符串数组来模拟大数的每一位,并手动处理了进位和借位的过程,避免了内置函数: ```java public class BigNumbers { // 定义一个静态变量作为分隔符 private static final String SEPARATOR = ""; /** * 合并两个字符串,形成一个新的字符串,用于表示较大的数字 * @param num1 第一个大数 * @param num2 第二个大数 * @return 结果字符串 */ public static String addOrSubtract(String num1, String num2, boolean isAddition) { int len1 = num1.length(), len2 = num2.length(); String result = new StringBuilder(Math.max(len1, len2)).toString(); // 初始化结果字符串 // 遍历两个数,从低位开始逐位相加相减 for (int i = Math.min(len1, len2); i > 0; --i) { int carry = 0; if (isAddition) { carry = num1.charAt(len1 - i - 1) - '0'; // 如果做加法,取num1的当前位 } else { carry = num2.charAt(len2 - i - 1) - '0'; // 如果做减法,取num2的当前位 } // 计算当前位的结果加上上一位置的进位 int sum = (carry + (isAddition ? num1.charAt(len1 - i) : num2.charAt(len2 - i))) - '0'; // 更新结果字符串,添加当前位的值和上一位的进位 result = result.substring(0, result.length() - 1) + (char)(sum % 10 + '0') + result.charAt(result.length() - 1); } // 检查剩余的小数点后的位,如果num1大于num2(减法),需要在结果前面加上一个小数点 if (!isAddition && len1 > len2) { result = "0." + result; } return result; } public static void main(String[] args) { // 测试数据 String num1 = "11502512222222"; String num2 = "56200003115610061"; // 加法操作 System.out.println("Addition: " + addOrSubtract(num1, num2, true)); // 减法操作 System.out.println("Subtraction: " + addOrSubtract(num1, num2, false)); } } ``` 在这个程序中,`addOrSubtract`方法接收两个字符串作为输入,通过循环遍历每个位来进行加法或减法运算。最后在`main`函数中展示了如何使用这个方法对给定的大数进行加法和减法操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一杯拿铁go

你的打赏是我更新最大的动力

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

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

打赏作者

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

抵扣说明:

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

余额充值