C#版 大数计算器--加法

本文探讨了在大型数字运算中使用抽象类和优化方法,包括数字反转、交换、比较和加法运算的实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

///
 

   /// 基类,抽象类,定义常用方法
    ///
    abstract class BigCalculate
    {
        public abstract string Oper(string num1, string num2);

        //反转数字顺序
        protected string InvertOrder(string str)
        {
            char[] chTemp = new char[str.Length];

            for (int i = 0; i < str.Length; i++)
            {
                chTemp[i] = str[str.Length - i-1];
            }

            return new string(chTemp.ToArray());
        }

        //交换数字
        protected void ChangeNum(ref string num1,ref string num2)
        {
            string strTemp = num1;
            num1 = num2;
            num2 = strTemp;
        }
        //获得较大数
        protected string Max(string num1, string num2)
        {
            if (num1.Length > num2.Length)
            {
                return num1;
            }
            else if (num1.Length==num2.Length)
            {
                for (int i = num1.Length-1; i >=0 ; i--)
                {
                    if (num1[i].CompareTo(num2[i])<0)
                    {
                        return num2;
                    }
                }
                return num1;
            }
            return num2;
        }
    }
--------------------------------------------------------------------------
    class BigAdd:BigCalculate
    {
        public override string Oper(string num1, string num2)
        {
            //获得较大数的位数
            int len = num1.Length > num2.Length ? num1.Length : num2.Length;
            //将较小数差位补0
            string tempNum1 = new string('0', len - num1.Length) + num1;
            string tempNum2 = new string('0', len - num2.Length) + num2;

            int flag = 0;//进位符
            List liCh = new List();//存放运算后数字
            for (int i = len - 1; i >= 0; i--)
            {
                liCh.Add((char)(tempNum1[i] + tempNum2[i] + flag - '0'));
                flag = (liCh[liCh.Count - 1] - '0') / 10;
                liCh[liCh.Count - 1] = (char)(((liCh[liCh.Count - 1] - '0') % 10) + '0');
            }

            //若运算完成后进位符不为0,及最高位进位,则再加一位
            if (flag > 0)
            {
                liCh.Add((char)(flag + '0'));
            }

            return InvertOrder(new string(liCh.ToArray()));
        }
    }

转载于:https://www.cnblogs.com/qiuyeyaozhuai/archive/2012/10/10/2719081.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值