我刚在学校里完成了一个写一个大加法器的任务.意思是一种可以将非常大的数字放在一起的方法.
我们有10分钟,我按时完成了.老师批准了.
我对结果不太满意,我想我可能采取了错误的方法.
这是我的版本:
using System;
using System.Text;
namespace kæmpe_adder
{
static class Program
{
static void Main()
{
var x = "1111";
var y = "111111111";
Console.WriteLine(BigAdder(x, y));
Console.ReadLine();
}
public static StringBuilder BigAdder(string x, string y)
{
var a = new StringBuilder(x);
var b = new StringBuilder(y);
return BigAdder(a, b);
}
public static StringBuilder BigAdder(StringBuilder x, StringBuilder y)
{
int biggest;
int carry = 0;
int sum;
var stringSum = new StringBuilder();
if (x.Length > y.Length)
{
y.FillString(x.Length - y.Length);
biggest = x.Length;
}
else if (y.Length > x.Length)
{
x.FillString(y.Length - x.Length);
biggest = y.Length;
}
else
{
biggest = y.Length;
}
for (int i = biggest - 1; i >= 0; i--)
{
sum = Convert.ToInt32(x[i].ToString()) + Convert.ToInt32(y[i].ToString()) + carry;
carry = sum / 10;
stringSum.Insert(0, sum % 10);
}
if (carry != 0)
{
stringSum.Insert(0, carry);
}
return stringSum;
}
public static void FillString(this StringBuilder str, int max)
{
for (int i = 0; i < max; i++)
{
str.Insert(0, "0");
}
}
}
}
当我写这篇文章时,我想到了你是如何用二进制文件做的.
是否有更短和/或更简单的方法来做到这一点?
最佳答案 从代数的角度来看,您的代码看起来是正确的.从设计的角度来看,您肯定更愿意将这些大数字封装在一个类中,这样您就不必一直引用字符串/字符串构建器.我也不是这种FillString方法的忠实粉丝,在两个数字都具有非零值的情况下添加数字似乎更合理,然后只需将进位添加到更大的数字,直到完成为止.
不确定关于二进制文件的问题是什么?正常长度数(32位和64位)由CPU作为单个操作添加.