大数相加和大数相减

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;
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
#include<stdio h> #include<string h> int main { int len1 len2 i j k t m; char str1[100] str2[100] str[100]; while scanf "%s %s" str1 str2 EOF { m 0; len1 strlen str1 ; len2 strlen str2 ; for i 0;i<len1;i++ str1[i] 48; for j 0;j<len2;j++ str2[j] 48; if len1 len2 {for i 0;i<len1;i++ { if str1[i]>str2[i] {for i len1 1 j len2 1 k 0;j> 1;i j k++ { if str1[i]<str2[j] {str1[i]+ 10;if str1[i 1]>0 str1[i 1] ;else {str1[i 1] 9;str1[i 2] ;}} str[k] str1[i] str2[j]; } break; } if str2[i]>str1[i] { for i len1 1 j len2 1 k 0;j> 1;i j k++ { if str1[i]>str2[j] {str2[j]+ 10;if str2[j 1]>0 str2[j 1] ;else {str2[j 1] 9;str2[j 2] ;}} str[k] str2[j] str1[i]; } printf " " ; break; } else{for i 0;i<len1;i++ str[i] 0;break;} } t len1 1; } if len1>len2 { for i len1 1 j len2 1 k 0;j> 1;i j k++ { if str1[i]<str2[j] {str1[i]+ 10;if str1[i 1]>0 str1[i 1] ;else {str1[i 1] 9;str1[i 2] ;}} str[k] str1[i] str2[j]; } for i len1 len2 1 k len2;k<len1;i k++ { str[k] str1[i]; } t len1 1; } if len1<len2 { for i len1 1 j len2 1 k 0;j> 1;i j k++ { if str1[i]>str2[j] {str2[j]+ 10;if str2[j 1]>0 str2[j 1] ;else {str2[j 1] 9;str2[j 2] ;}} str[k] str2[j] str1[i]; } for j len2 len1 1 k len1;k<len2;j k++ { str[k] str2[j]; } printf " " ; t len2 1; } for i t;i> 1;i { if m 0 printf "%d" str[i] ; if m 0&&str[i] 0 {printf "%d" str[i] ;m++;} } if m 0 printf "0" ; printf " n" ; } return 0; }">#include<stdio h> #include<string h> int main { int len1 len2 i j k t m; char str1[100] str2[100] str[100]; while scanf "%s %s" str1 str2 EOF { m 0; len1 strlen str1 ; len2 strlen str2 ; for i 0;i<len1;i++ str1[i] 48; for j 0;j<len2;j++ str2[j] 48; if len1 len2 [更多]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一杯拿铁go

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

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

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

打赏作者

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

抵扣说明:

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

余额充值