C语言大数运算-减法篇

前言:
前面介绍了有关的思想,和本片博客的测试环境,所以作为第二篇的减法篇就不再过多的介绍,直接开始关于大数加法的实现。

大数减法:
与加法类似,还是将用户的输入和结果放入变长的数组中然后模仿手工运算从低位到高位依次相减,会有三个需要解决的问题,其中前二个和大数加法的问题很相似,所以就不再详细说明。

问题:
1.结果最多有多少位?
2.借位的算法如何实现?
3.如果一个8位数减去4位数,那么8位数较高的4位如何处理?
前两个问题参考大数加法都可以得到解决。
1.结果的最大位数和较大的减数位数相同,所以结果数组的长度可以和减数位数相同。
2.同加法类似,先存储每位相减的结果然后在用一个循环作整理。
3.可以把被减数缺少的位数用零补全然后相减,也可以只减到被减数的位数,然后将减数的高位直接写道结果的数组中。

注意:
本算法只可以拿大数减小数,因为小数减大数只不过还是拿大的减小的然后加个负号而已,所以本着简洁的原则,只允许用大数减去小数。

实现:
同加法一样还是把减法写成方法,然后在mian函数中调用,下面是完整的有详细注释的代码。

  1 //#include"big.h"
  2 #include<stdlib.h>
  3 #include<stdio.h>
  4 #include<string.h>
  5 char * bigsub(char *suba,int lena,char *subb,int lenb){  //大数减法的的方法。
  6   int lensum,num='0';
  7   int i,j,k,tmp;
  8   lensum=lena>lenb?lena:lenb;
  9   for(i=0;i<lena;i++){                                   //将ASCII编码的数字转换为真正的数字存储,便于计算。
 10       suba[i]=suba[i]-num;                               //大数加法注释中有例子。
 11   }
 12   for(i=0;i<lenb;i++){
 13       subb[i]=subb[i]-num;
 14   }
 15     char *result,final[BUFSIZ];
 16     result=(char*)calloc(lensum,1);                      //动态分配内存空间,在大数加法中忘记介绍
 17     for(i=0,j=0;i<lena&&j<lenb;i++,j++){                 //calloc()有两个参数,本次会分配 ‘lensum’ 个大小为 ‘1’ 字节的内存空间
 18       result[i]=suba[lena-i-1]-subb[lenb-i-1];           //并且全部初始化为0,返回指向内存的指针
 19     }
 20     if(lena>lenb){                        //判断,并将高位写入result结果数组中。
 21       for(i=lenb;i<lena;i++){
 22          result[i]=suba[lena-i-1];
 23       }
 24     }
 25     if(lenb>lena){                        //由于只允许大减小所以这个判断可以删除。
 26       for(i=lena;i<lenb;i++){
 27          result[i]=subb[lenb-i-1];
 28       }
 29     }
 30     for(k=0;k<lensum-1;k++){              //整理结果,同大数加法类似,只是判断方法变了而已。
 31       if(result[k]<0){
 32          result[k]=result[k]+10;
 33          result[k+1] -=1;
 34       }
 35     }
 36     j=0;
 37     if(result[lensum-1]!=0){             //将结果集去除前导0后整理到final数组中。
 38       final[j]=result[lensum-1]+num;
 39       j++;
 40     }
 41     for(i=lensum-2;i>=0;i--){
 42       final[j++]=result[i]+num;
 43 
 44     }
 45     result=final;                        //将指针指向final数组并返回数组的指针。
 46     return result;
 47 }
 48 int main(){                                                 //利用main测试方法,用puts打印结果。               
 49    int lena,lenb;
 50    char *result,sa[BUFSIZ],sb[BUFSIZ];
 51    scanf("%s",sa);
 52    scanf("%s",sb);
 53    lena=strlen(sa);
 54    lenb=strlen(sb);
 55    result=bigsub(sa,lena,sb,lenb);
 56    puts(result);
 57 
 58 } 

下一篇是大数乘法和除法。

  • 10
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在C语言中进行大数运算,一般有以下几种方式: 1. 自己实现高精度计算库:通过定义自己的数据结构(比如用数组表示大整数)和实现基本的大数加减乘除等运算,可以实现高精度计算。但是这需要自己实现大量的代码,而且效率可能不如专业的大数计算库。 2. 使用现有的大数计算库:有一些现成的开源大数计算库(比如GNU MP库),可以在C语言中直接调用。使用这些库可以避免自己实现大量的代码,同时也可以获得高效的运算性能。 无论采用哪种方式,都需要了解大数运算的原理和具体实现方式,以及注意处理边界情况和错误情况,以保证计算的正确性和可靠性。 ### 回答2: 大数运算是指处理超过计算机整数位数上限的数值运算C语言是一种基础的编程语言,它没有内置针对大数运算的数据类型和运算符,但可以通过自定义数据结构和算法实现大数运算。 一种常用的实现大数运算的方法是使用数组来表示大数。具体步骤如下: 1. 定义一个足够长的数组,用于存储大数的每一位,数组的长度应根据需要处理的数值范围确定。 2. 将大数按照逆序的方式存储在数组中,即个位数存储在数组的第一个元素,十位数存储在数组的第二个元素,依次类推。 3. 实现基本的加法、减法、乘法和除法运算函数。对于加法和减法,可以从个位数开始逐位相加或相减,将结果存储在新的数组中,并考虑进位或借位;对于乘法和除法,可以参考手动计算的方法,将运算结果逐步存储在新的数组中。 4. 根据需要,还可以实现其他的运算操作,如取模运算、幂运算等。 需要注意的是,由于大数计算涉及到多位数的运算,所以处理起来相对较慢,需要考虑计算时间和内存占用。同时,大数运算中也需要考虑到运算结果溢出的问题,以及负数运算的处理等。 综上所述,通过使用数组和自定义算法,我们可以利用C语言进行大数运算。这样可以扩展C语言在数值计算方面的能力,应对一些特殊的计算需求。 ### 回答3: 在C语言中进行大数运算可以通过使用字符串来表示和计算大数。以下是一种简单的实现方法: 1. 首先,将要进行运算大数转换成字符串表示。可以使用字符数组来表示,例如char number[100],其中100是一个足够大的长度以容纳大数。 2. 定义一个结构体来表示大数,结构体中包含一个字符数组和一个记录大数位数的变量。例如: ```c struct BigInt { char digit[100]; int length; }; ``` 3. 编写函数来实现大数的基本运算,例如加法、减法、乘法和除法。对于加法和减法运算,可以模仿手动计算时的竖向计算方法,从低位数开始逐位相加或相减,同时注意进位或借位。 4. 对于乘法和除法运算,可以借助于循环和进位(借位)的操作,逐位相乘或相除,并将结果保存在一个新的字符数组中。 5. 在进行运算时,为了方便操作,可以将字符串的字符顺序进行逆序,从而在计算过程中更容易按照从低位到高位的顺序进行。 6. 编写其他必要的辅助函数,例如比较大小、取反等。 请注意,大数运算是一种复杂的问题,需要考虑到边界情况和错误处理。以上仅是一种简单的实现方法,对于更复杂的大数运算问题还需要进一步的优化和改进。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值