C#-多项式除法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了C#-多项式除法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1123字,纯文字阅读大概需要2分钟。
内容图文
我正在编写一个程序来计算多项式的运算,并且我已经完成了其他运算(-*)但卡在除法上,但我总是收到此错误,如代码所示
static int[] DividePolnomials(int[] pol1, int[] pol2)
{
int tmp = 0;
int power_tmp = 0;
int[] result_tmp;
int[] result;
if (pol1.Length > pol2.Length)
{
result = new int [pol1.Length];
result_tmp = new int[pol1.Length];
for (int i = 0; pol2.Length<=pol1.Length; i++)
{
if (pol2[pol2.Length-i-1] == 0) // here is the problem it gives that the index is outside the bounds
{
continue;
}
else
{
tmp = pol1[pol1.Length - i - 1] / pol2[pol2.Length - i - 1];
power_tmp = (pol1.Length - i - 1) - (pol2.Length - i - 1);
result[power_tmp] = tmp;
result_tmp = Multiply(result, pol2);
pol1 = SubtractPolnomial(pol1, result_tmp);
}
}
}
else
{
result = new int [pol1.Length];
}
return result;
}
由于此错误,我尚未完成代码中的所有其他方案,但是如果两个多项式的长度相等,我想获得任何帮助
解决方法:
您的i变得大于pol2.Length-1,因此此时您具有pol2 [-1],pol2 [-2]等.这在C#中是不允许的.您可以检查下一条语句:
if ((pol2.Length-i-1 < 0) || (pol2[pol2.Length-i-1] == 0))
{
continue;
}
编辑:如果第一个条件为真,第二个将不被评估
https://msdn.microsoft.com/en-us/library/6373h346.aspx
内容总结
以上是互联网集市为您收集整理的C#-多项式除法全部内容,希望文章能够帮你解决C#-多项式除法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。
来源:【匿名】