当前位置: 首页 > news >正文

大整数乘法-表格法

执行文件和项目文件
链接: http://pan.baidu.com/s/1dELptrr 密码: hndy

clipboard.png

exe运行截图

clipboard.png

计算器比较

clipboard.png

原理

clipboard.png

  • 初始化,表格,将输入的A,B字符串填入表格

  • 计算对应的乘积,注意错位,填入表格

  • 考虑进位,将每一位对应的值,填入最后一行,最后一行连成的字符串即是C值

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace bigNum_form
{
    public partial class Form1 : Form
    {
       private  string a = "";
       private  string b = "";
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            textBox3.Text = "";
            a = textBox1.Text;
            b = textBox2.Text;
            bigNum num = new bigNum { A = a, B = b };
            num.initC();
            num.compute();
            num.go_loc();
            num.answerOut();
            textBox3.Text = num.Answer;
            textBox3.Show();
        }
        public class bigNum
        {
            private string a = "";
            private string b = "";
            private string answer = "";
            public string A
            {
                get
                {
                    return a;
                }
                set
                {
                    int i = 0, mark = 0;
                    while (i < value.Length)
                    {
                        if (!Char.IsNumber(value[i]))
                        {
                            mark = 1;
                        }
                        i++;
                    }
                    if (mark == 0)
                        a = value;
                }
            }
            public string B
            {
                get
                {
                    return b;
                }
                set
                {
                    int i = 0, mark = 0;
                    while (i < value.Length)
                    {
                        if (!Char.IsNumber(value[i]))
                        {
                            mark = 1;
                        }
                        i++;
                    }
                    if (mark == 0)
                        b = value;
                }
            }

            public string Answer
            {
                get
                {
                    return answer;
                }
            }
            private int[,] C = new int[100, 100];

            public void initC()
            {
                //A第一行,1~a.length,填入C
                for (int i = 1; i <= a.Length; i++)
                {
                    C[0, i] = a[i - 1] - '0';
                }
                //B第一列,1~b.length,填入C
                for (int j = 1; j <= b.Length; j++)
                {
                    C[j, 0] = b[j - 1] - '0';
                }
            }

            public void compute()
            {
                //遍历B
                int miss = 0;//记录错位
                for (int i = 1; i <= b.Length; i++)
                {
                    for (int j = 1; j <= a.Length; j++)
                    {
                        C[i, j + miss] = C[i, 0] * C[0, j];
                    }
                    miss++;
                }
            }

            public void go_loc()//进位
            {
                //从最后一列开始,没列相加
                //总和%10——>最后行
                //总和/10——>进位数
                int c = 0;//进位数
                int sum = 0;
                for (int i = a.Length + b.Length - 1; i > 0; i--)
                {
                    sum = 0;
                    for (int j = 1; j <= b.Length; j++)
                    {
                        sum += C[j, i];
                    }
                    sum += c;//低位进位数
                    C[b.Length + 1, i] = sum % 10;
                    c = sum / 10;
                }
                C[b.Length + 1, 0] = c;
            }

            public void answerOut()
            {
                Char an;
                if (C[b.Length + 1, 0] != 0)
                {
                    an = (Char)(C[b.Length + 1, 0] + '0');
                    answer += an.ToString();
                }
                for (int i = 1; i <= a.Length + b.Length - 1; i++)
                {
                    an = (Char)(C[b.Length + 1, i] + '0');
                    answer += an.ToString();
                }
            }
        }

}

相关文章:

  • 2.2《框架通讯契约——接口》
  • 【重要更新】强大的文档管理工具包Aspose.Total 2017年中更新大合集
  • VC、IE、ASP环境下打印、预备的完美解决方式
  • Oracle list
  • Silverlight初级教程-库
  • Happiness
  • 解决Server Application Unavailable问题
  • 用TensorFlow实现文本分析模型,做个聊天机器人
  • 转载:什么是高级C++?
  • AV Foundation 的剖析 1.0
  • 红旗Linux+Oracle10g
  • vue30-单一事件管理组件通信: vuex
  • C#和ASP.Net面试题目集锦
  • java 基础概念 -- 数组与内存控制
  • (求助)用傲游上csdn博客时标签栏和网址栏一直显示袁萌 的头像
  • JS中 map, filter, some, every, forEach, for in, for of 用法总结
  • 收藏网友的 源程序下载网
  • 《深入 React 技术栈》
  • 【162天】黑马程序员27天视频学习笔记【Day02-上】
  • 【译】React性能工程(下) -- 深入研究React性能调试
  • 0x05 Python数据分析,Anaconda八斩刀
  • bootstrap创建登录注册页面
  • Docker: 容器互访的三种方式
  • ES2017异步函数现已正式可用
  • orm2 中文文档 3.1 模型属性
  • PHP的Ev教程三(Periodic watcher)
  • Promise初体验
  • react-core-image-upload 一款轻量级图片上传裁剪插件
  • React-Native - 收藏集 - 掘金
  • swift基础之_对象 实例方法 对象方法。
  • v-if和v-for连用出现的问题
  • vue-router 实现分析
  • 阿里云应用高可用服务公测发布
  • 番外篇1:在Windows环境下安装JDK
  • 高度不固定时垂直居中
  • 关于字符编码你应该知道的事情
  • 判断客户端类型,Android,iOS,PC
  • 深度学习在携程攻略社区的应用
  • 使用SAX解析XML
  • 为什么要用IPython/Jupyter?
  • 优秀架构师必须掌握的架构思维
  • 白色的风信子
  • 如何正确理解,内页权重高于首页?
  • ​低代码平台的核心价值与优势
  • (附源码)ssm智慧社区管理系统 毕业设计 101635
  • (完整代码)R语言中利用SVM-RFE机器学习算法筛选关键因子
  • (转)Android中使用ormlite实现持久化(一)--HelloOrmLite
  • ******IT公司面试题汇总+优秀技术博客汇总
  • .dat文件写入byte类型数组_用Python从Abaqus导出txt、dat数据
  • .net redis定时_一场由fork引发的超时,让我们重新探讨了Redis的抖动问题
  • .NET/C# 在代码中测量代码执行耗时的建议(比较系统性能计数器和系统时间)...
  • .net实现头像缩放截取功能 -----转载自accp教程网
  • @Mapper作用
  • [ CTF ]【天格】战队WriteUp- 2022年第三届“网鼎杯”网络安全大赛(青龙组)
  • [@Controller]4 详解@ModelAttribute