例如,如果这是关系:
3x - 5y + z = 5
我不想这样编码:
function(int x,int y){ return 5 - 3x + 5y;}function(int x,int z){ return (5 - z - 3x)/(-5);}
等等.是否有一种标准的方式来处理这样的编程问题?也许使用矩阵,参数化等?
解决方法 如果您将自己局限于上面所示的线性函数,可以像这样推广函数3x - 5y + z = 5
会成为
a[0]*x[0] + a[1]*x[1] + a[2]*x[2] = c
a = {3,-5,1}且c = 5.
即,您需要一个常数因子列表(或数组)List< double>一个;和变量列表List< double?> X;再加上右侧的常数双c;
public double Solve(IList<double> a,IList<double?> x,double c){ int unkNowns = 0; int unkonwnIndex = 0; // Initialization required because the compiler is not smart // enough to infer that unkNownIndex will be initialized when // our code reaches the return statement. double sum = 0.0; if (a.Count != x.Count) { throw new ArgumentException("a[] and x[] must have same length"); } for (int i = 0; i < a.Count; i++) { if (x[i].HasValue) { sum += a[i] * x[i].Value; } else { unkNowns++; unkNownIndex = i; } } if (unkNowns != 1) { throw new ArgumentException("Exactly one unkNown expected"); } return (c - sum) / a[unkNownIndex];}
例:
3x - 5y + z = 5 5 - (- 5y + z)x = -------------- 3
如示例所示,解决方案包括从常量中减去除未知项之外的所有项的总和,然后除以未知因子.因此,我的解决方案记住了未知的索引.
假设你有等式,你可以用这样的幂来推广
a[0]*x[0]^p[0] + a[1]*x[1]^p[1] + a[2]*x[2]^p[2] = c
你需要一个额外的参数IList< int> p,结果变成了
return Math.Pow((c - sum) / a[unkNownIndex],1.0 / p[unkNownIndex]);
因为x ^(1 / n)等于第n个根(x).
如果你使用双打作为权力,你甚至可以代表像这样的功能
57*x^3 + --- + 4*sqrt(z) = 11 y^2a = { 7,5,4 },p = { 3,-2,0.5 },c = 11
因为
1x^(-n) = --- x^n
和
nth-root(x) = x^(1/n)
但是,您将无法找到真正的非线性多项式的根,例如x ^ 2 – 5x = 7.如果未知在方程中恰好出现一次,则上面显示的算法仅起作用.
总结以上是内存溢出为你收集整理的c# – 如果未知变量发生变化,是否有解决单个未知的一般方法?全部内容,希望文章能够帮你解决c# – 如果未知变量发生变化,是否有解决单个未知的一般方法?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)