c语言实现大数运算加法

1 大数的概念

首先我们知道在编译系统中是可以实现加法,但是我们所定义的数据类型是有限的

int(四字节)时数的范围为-2147483648~2147483647[-2^31~2^31-1];

即使是long long int 的数据范围为-9223372036854775808~9223372036854775807

[-2^64~2^64-1]。

而在实际的计算中是十分有可能遇到位数大于几千位的数字,显然我们c语言现在所有的数据结构类型是无法满足,那么我们该采用什么样的方法来实现这种运算呢?

首先大家思考一下在计算小数的时候我们是如何实现的我们以一下面的一个例子来探讨一下:

#include<stdio.h>
int main()
{
    int a=3;
    int b=4;
    int c=a+b;
    printf("%d",c);
return 0;
}

1 数据的读入。

2 进行计算。

 3 输出结果。


1 数据的读入

       那么我先要解决的问题就是大数的读入,我们前面说的任何一种数据结构都无法满足,所以要想一种可以装下任意位数的东西,想一想数组是不是满足以上的要求呢?

接下来我就来介绍一下数据的读入的方法,话不多说先上代码。 

#include<stdio.h>
int main()
{

     int c[100010]; int d[100010];
     int e[100010];
    char a[100010];char b[100010];
    gets(a); gets(b);
    int strlen_a=check(a);
    int strlen_b=check(b);
    int strlen_e=0;
    for(int i=strlen_a-1;i>-1;i--)是将字符转换位整数。
        c[strlen_a-i-1]=a[i]-'0';
    for(int i=strlen_b-1;i>-1;i--)
        d[strlen_b-i-1]=b[i]-'0';
 }
int check(char array[])//该函数用来计算输入的实际位数。
{
    int i=0;
    for(i=0;;i++)
        if(*(array+i)==NULL)
            break;
    return i;
}

接下来讲解一下其中的核心部分

for(int i=strlen_b-1;i>-1;i--)
        d[strlen_b-i-1]=b[i]-'0'; 

1 i=strlen_b-1,其中减一是因为字符数组的结尾会有一个'\0'。

2 d[strlen_b-i-1]=b[i]-'0',这里面有两个要点要说明:

A : d[strlen_b-i-1]=b[i]-'0',从整体上来看这条语句的作用是将字符数组b中的数据倒置进入整形数组d中并完成从字符型到整形的转换。

B : b[i]-'0' 因为在ASCII中为0,所以b[i]-0,可以直接转化。


 2 进行计算。

        那么我们我们如何进行计算呢?是否还是像之前一样进行计算吗?答案当然不,我们要使用一种更古老的方法来解决这个问题——模拟列竖式来计算。老规矩我们先上代码,等等上代码之前我们先解决一些大家的疑惑。

A   我们倒置的原因,大家回想一下在小学的时候学习列竖式的时候我们是从个位开始算起,其一原因就是因为从个位开始便于我们的进位。其二大家想一种情况像99+1这种情况下结果是100,如果我们才取正序的方法来计算的时候就会出现a[0]=0,a[1]=0,那么通过进位得到的1,就无法在a[0]前面插入1,那么下一步我们就需要重新分配一段连续的内存空间来计录结果,这样做不仅消耗运行时间有会使代码冗长。

在这里跟大家说一下实现高精度计算的方法不止电脑模拟列竖式一种方法,

现在正式上代码

int add(int  array1[],int array2[],int strlen_array1,int strlen_array2)
{
	int i,t=0,j=0;
	for(i=0;i<strlen_array1||i<strlen_array2;i++)
	{
		if(i<strlen_array1) t+=array1[i];
		if(i<strlen_array2) t+=array2[i];
		e[i]=t%10;
		t/=10;
	}
	if(t) e[i]=1;
	return i;

最后上完整代码

#include<stdio.h>
#include<string.h>
char a[100010];char b[100010];
int c[100010]; int d[100010];
int e[100010];
int check(char array[])
{
	int i=0;
	for(i=0;;i++)
		if(*(array+i)==NULL)
			break;
	return i;
}
int add(int  array1[],int array2[],int strlen_array1,int strlen_array2)
{
	int i,t=0,j=0;
	for(i=0;i<strlen_array1||i<strlen_array2;i++)
	{
		if(i<strlen_array1) t+=array1[i];
		if(i<strlen_array2) t+=array2[i];
		e[i]=t%10;
		t/=10;
	}
	if(t) e[i]=1;
	return i;
}
int main()
{
	gets(a); gets(b);
	int strlen_a=check(a);
	int strlen_b=check(b);
	int strlen_e=0;
	for(int i=strlen_a-1;i>-1;i--)
		c[strlen_a-i-1]=a[i]-'0';
	for(int i=strlen_b-1;i>-1;i--)
		d[strlen_b-i-1]=b[i]-'0';
	strlen_e=add(c,d,strlen_a,strlen_b);
	int i=0;
	for(i=strlen_e;;i--)
		if(e[i]!=0)
			break;
	for(;i>=0;i--)
		printf("%d",e[i]);
	return 0;
}

        

  • 4
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值