在C#中,我们经常需要表示整数。但是,c#的基本数据类型中,最大的long也只能表示-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807之间的数。货币类型也不是无限大。如果我们需要表示更大的数,就需要用到一定的算法来完成。

这次,我和大家一起讨论一下c#的大数运算之加法。

这次,我们只考虑正数的整数加法。

我们的代码要封装到一个结构里面。这个结构的结构先摆出来。

 public struct BigInt
{ public int[] num ;
public int length ; }

我们的思路是读取一个string表示的大数,然后通过算法来计算,返回一个string类型的结果。

为了便于计算,我们首先要把赋值过来的的string转换为一个int数组。这个数组就是代码里的num[]数组。

我们要把这个数的个位存到num[0]里,十位存到num[1]里,以此类推。于是我添加了一个构造函数。

  public BigInt(string theint):this()
{ this.num = new int[];
this.length = ;
this.length = theint.Length - ;
for (int i = ; i <= theint.Length - ; i++)
{
this.num[i] = Convert.ToInt32(theint[theint.Length - - i].ToString()); }
}

例如 调用BigInt(“123”) 时,num[0]=3,num[1]=2,num[2]=1 length=2 (为了方便,这里的length是指数组的坐标上限,不是数组元素的个数)

我们如果能直接把string赋给BigInt类型的变量该多方便啊,那么我们现在就来实现它。 怎么实现呢?其实把一种数据类型变量赋值给另一种时,都需要转换,为什么有的可以直接赋值呢,是因为这里进行的是隐式转换。所以我们就来编写从string到BigInt的隐式转换。代码和构造函数类似。

 public static implicit operator BigInt(string theint)
{
BigInt b = new BigInt(); b.num = new int[];
b.length = ;
b.length = theint.Length - ;
for (int i = ; i <= theint.Length - ; i++)
{
b.num[i] = Convert.ToInt32(theint[theint.Length - - i].ToString()); }
return b;
}

implicit说明转换方式是隐式转换。operator是各种转换和操作符的标志。

当然,较小的数也可以直接从int转过来。所以再写一个int=>BigInt的隐式转换。

 public static implicit operator BigInt(long theint2)
{
string theint = theint2.ToString(); return theint;
}

准备工作做好了,现在开始计算过程。

在这里,我们通过模拟学生列竖式的方法来计算。首先要从最低位也就是个位加起,满10要向高位进1,也就是数组的下一个元素的值加一。我们直接重写+操作符,代码见下

  public static BigInt operator +(BigInt b1, BigInt b2)
{
BigInt b3 = b1;//要返回的加法结果
BigInt b4 = b2;
int big = b3.length > b4.length ? b3.length : b4.length;//获取两个加数的最高位数,从0到最高位数依次加法 for ( int i = ; i <= big; i++) {
b3.num[i] += b4.num[i];//加法计算
b3.num[i + ] += b3.num[i] / ;//进位
b3.num[i] %= ; //进位后剩下的
}
//确定更新后的位数
big=;
while (b3.num[big] == &&big!=) {
big--;
}
b3.length = big;
return b3;
}
 public static BigInt operator +(BigInt b1, BigInt b2)这一句,BigInt是加法返回的结果的类型;operator +说明重写的是加法,(BigInt b1, BigInt b2)是两个加数。计算原理是竖式的加法计算。
代码里我加入了注释,应该可以看懂

最后,为了显示BigInt类型的值,我们编写一个由BigInt到string的隐式转换。

public static implicit operator string(BigInt theint)
{
string b = ""; for (int i = theint.length; i >= ; i--)
{
b += theint.num[i].ToString();
}
return b;
}

由于存入数组时时从低位到高位的,所以我们输出string时要反转回来。

至此,大数加法编写完成。下面是代码清单。

public struct BigInt
{ public int[] num ;
public int length ;
#region 初始赋值 public BigInt(string s):this()
{
this = s;
}
public static implicit operator BigInt(string theint)
{
BigInt b = new BigInt(); b.num = new int[];
b.length = ;
b.length = theint.Length - ;
for (int i = ; i <= theint.Length - ; i++)
{
b.num[i] = Convert.ToInt32(theint[theint.Length - - i].ToString()); }
return b;
}
public static implicit operator BigInt(long theint2)
{
string theint = theint2.ToString(); return theint;
}
#endregion public static implicit operator string(BigInt theint)
{
string b = ""; for (int i = theint.length; i >= ; i--)
{
b += theint.num[i].ToString();
}
return b;
}
 public static BigInt operator +(BigInt b1, BigInt b2)
{
BigInt b3 = b1;//要返回的加法结果
BigInt b4 = b2;
int big = b3.length > b4.length ? b3.length : b4.length;//获取两个加数的最高位数,从0到最高位数依次加法 for ( int i = 0; i <= big; i++) {
b3.num[i] += b4.num[i];//加法计算
b3.num[i + 1] += b3.num[i] / 10;//进位
b3.num[i] %= 10; //进位后剩下的
}
//确定更新后的位数
big=199;
while (b3.num[big] == 0&&big!=0) {
big--;
}
b3.length = big;
return b3;
}
} 

另外注,此贴纯属技术研究,如需大数运算,.net有专门的类型,无需自己写代码。至于类型是什么,你们自己去找吧。O(∩_∩)O~

c#大数加法的更多相关文章

  1. 51nod 1005 大数加法

    #include<iostream> #include<string> using namespace std; #define MAXN 10001 },b[MAXN]={} ...

  2. 玲珑杯1007-A 八进制大数加法(实现逻辑陷阱与题目套路)

    题目连接:http://www.ifrog.cc/acm/problem/1056 DESCRIPTION Two octal number integers a, b are given, and ...

  3. Leetcode 67 Add Binary 大数加法+字符串处理

    题意:两个二进制数相加,大数加法的变形 大数加法流程: 1.倒置两个大数,这一步能使所有大数对齐 2.逐位相加,同时进位 3.倒置两个大数的和作为输出 class Solution { public: ...

  4. HDU1002大数加法

    大数加法 c++版: #include <map> #include <set> #include <stack> #include <queue> # ...

  5. java实现大数加法、乘法(BigDecimal)

    之前写过用vector.string实现大数加法,现在用java的BigDecimal类,代码简单很多.但是在online-judge上,java的代码运行时间和内存大得多. java大数加法:求a+ ...

  6. vector、string实现大数加法乘法

    理解 vector 是一个容器,是一个数据集,里边装了很多个元素.与数组最大的不同是 vector 可以动态增长. 用 vector 实现大数运算的关键是,以 string 的方式读入一个大数,然后将 ...

  7. 【大数加法】POJ-1503、NYOJ-103

    1503:Integer Inquiry 总时间限制:  1000ms 内存限制:  65536kB 描述 One of the first users of BIT's new supercompu ...

  8. A + B Problem II 大数加法

    题目描述: Input The first line of the input contains an integer T(1<=T<=20) which means the number ...

  9. NI笔试——大数加法

    NI笔试: 1.找出字符串第一次出现的字符.用数组建立哈希表,然后再扫描字符串并判断次数是否为1. 2.大数加法,即字符串加法.因为之前写过乘法,就以为是乘法.然后就把乘法写上去了····= = 好了 ...

随机推荐

  1. hihoCoder#1094

    刚开始学习C语言,准备在做hiho的题目的过程中来学习,在此进行记录,如果代码中有错误或者不当的地方还请指正. 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 Littl ...

  2. js②

    操作符 ECMA-262描述了一组用于操作数据值的操作符,包括算术操作符(如加号和减号).位操作符.关系操作符和相等操作符. 一元操作符 递增和递减操作符(++ --) 一元加和减操作符 对非数值应用 ...

  3. red hat enterprise 6安装tftp服务

    1--->检查是否安装tftp rpm -qa tftp* 2--->安装tftp yum install -y tftp-server 3--->chkconfig --list| ...

  4. 解决ORA-14450:试图访问已经在使用的事务处理临时表

    select * from dba_objects where object_name='TEMP_MZGL_BRSFD'; select 'alter system kill session ''' ...

  5. 构造一个简单的Linux系统MenuOS

    陈智威20135125 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 实验指导 ...

  6. css中文乱码与替换字符

    有时候,我们的css样式表中字体乱码,很诧异.百度谷歌是两个老师,有时jquery博客还上淘宝,那边有现成的代码,看看,发现里面定义全局字体是这样的font:12px/1.5 tahoma,arial ...

  7. 学习linux/unix编程方法的建议(转)

    假设你是计算机科班出身,计算机系的基本课程如数据结构.操作系统.体系结构.编译原理.计算机网络你全修过 我想大概可以分为4个阶段,水平从低到高从安装使用=>linux常用命令=>linux ...

  8. 华为交换机sflow配置

    华为交换机sflow功能配置 1.配置交换机的sflow流发送 [系统视图]sflow agen ip  x.x.x.x                 设置sflow输出源 [系统视图]sflow ...

  9. Linux内核分析——分析system_call中断处理过程

    万子惠 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 我选择的是get ...

  10. day04关于MySqL—Android小白的学习笔记

    Mysql入门 1. 数据库基本知识(了解) 1.1.数据库介绍 1.1.1.什么是数据库?数据库的作用是什么? 数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户 ...