C# 二元一次方程参数求解
本文记录了关于求直线斜率及纵截距值的简单方法,只是简单的记录下求解思路,最终还需根据具体项目进行优化。
设直线方程式为:y=kx+b
编程思想:
1、代入y1与x1的值,得到:y1=kx1+b
2、代入y2与x2的值,得到:y2=kx2+b
3、首先算出一个系数m=kx1 / kx2 或 m=kx2 / kx1
4、根据第三步,将 y1=kx1+b 或 y2=kx2+b 乘以系数m,使 kx1==kx2 ,注意 kx1与kx2不能为0
4、将2个函数相减,例如:my2-my1=mb-b 即 m(y2-y1)=(m-1)b
5、算出纵截距b=(m(y2-y1))/(m-1) 注意:m不能为1 同时注意浮点数四舍五入问题
6、将b值y1=kx1+b中,求出斜率k值
示例代码:
using System; namespace Demo { class Program { ;//小数位数保留2位 /// <summary> /// 计算斜率k及纵截距b值 /// </summary> /// <param name="x1">坐标点x1</param> /// <param name="x2">坐标点x2</param> /// <param name="y1">坐标点y1</param> /// <param name="y2">坐标点y2</param> /// <param name="kvalue">斜率k值</param> /// <param name="bvalue">纵截距b值</param> private static void Calculate(float x1, float x2, float y1, float y2, ref float kvalue, ref float bvalue)//求方程y=kx+b 系数 k ,b { ;//系数值 try { ) || (x2 == ) || (x1 == x2)) return; //排除为零的情况以及x1,x2相等时无法运算的情况 //if (y1 == y2) return; //根据具体情况而定,如何这两个值相等,得到的就是一条直线 ; if (x1 >= x2) { coefficient = (float)Math.Round((x1 / x2), _decimaldigits); temp = y2 * coefficient; //将对应的函数乘以系数 bvalue = ()), _decimaldigits); kvalue = (float)Math.Round(((y1 - bvalue) / x1), _decimaldigits); //求出k值 } else { coefficient = x2 / x1; temp = y1 * coefficient; bvalue = ()), _decimaldigits);//求出b值 kvalue = (float)Math.Round(((y2 - bvalue) / x2), _decimaldigits); //求出k值 } } catch { Console.WriteLine("x系数不能为0或相等"); } } static void Main(string[] args) { ; ; ; ; ; ; Console.WriteLine("计算直线斜率k及纵截距b"); Console.WriteLine("请输入x1值"); x1 = Convert.ToSingle(Console.ReadLine()); Console.WriteLine("请输入y1值"); y1 = Convert.ToSingle(Console.ReadLine()); Console.WriteLine("请输入x2值"); x2 = Convert.ToSingle(Console.ReadLine()); Console.WriteLine("请输入y2值"); y2 = Convert.ToSingle(Console.ReadLine()); Calculate(x1, x2, y1, y2, ref kvalue, ref bvalue); Console.WriteLine("直线方程为:y={0}x+{1}", kvalue, bvalue); Console.ReadKey(); } } }
运行结果:
C# 二元一次方程参数求解的更多相关文章
- flink 批量梯度下降算法线性回归参数求解(Linear Regression with BGD(batch gradient descent) )
1.线性回归 假设线性函数如下: 假设我们有10个样本x1,y1),(x2,y2).....(x10,y10),求解目标就是根据多个样本求解theta0和theta1的最优值. 什么样的θ最好的呢?最 ...
- SA:T1编写主函数法和T2Matlab自带的SA工具箱GUI法,两种方法实现对二元函数优化求解——Jason niu
%SA:T1法利用Matlab编写主函数实现对定义域[-5,5]上的二元函数求最优解—Jason niu [x,y] = meshgrid(-5:0.1:5,-5:0.1:5); z = x.^2 + ...
- 使用代数方程库 Algebra.js解二元一次方程
假设二元一次方程如下: x + y = 11 x - y = 5 解方程如下: <!DOCTYPE html> <html lang="zh-CN"> &l ...
- ACM_鸡兔同笼(二元一次方程)
鸡兔同笼 Time Limit: 2000/1000ms (Java/Others) Problem Description: 今有雉兔同笼,上有n头,下有m足,问雉兔各几何? Input: 输入有多 ...
- # 「银联初赛第一场」自学图论的码队弟弟(dfs找环+巧解n个二元一次方程)
「银联初赛第一场」自学图论的码队弟弟(dfs找环+巧解n个二元一次方程) 题链 题意:n条边n个节点的连通图,边权为两个节点的权值之和,没有「自环」或「重边」,给出的图中有且只有一个包括奇数个结点的环 ...
- matlab求解二元一次方程组的解得表达式
- 利用Python求解二元一次方程
本程序流程如下: (1)输入A.B.C (2)计算△ (3)判断解的个数 (4)计算解 (5)输出解 求:x2-3x+2=0的解 #输入A.B.C A=float(input("输入A:&q ...
- 使用python实现解析二元一次方程
二元一次函数的实现 import cmathimport mathimport sys 这里导入cmath包是在后面用来处理复数的情况导入math使用来处理 平方 根号等的运算而导入sys的意义是为了 ...
- HDU 4793 Collision (解二元一次方程) -2013 ICPC长沙赛区现场赛
题目链接 题目大意 :有一个圆硬币半径为r,初始位置为x,y,速度矢量为vx,vy,有一个圆形区域(圆心在原点)半径为R,还有一个圆盘(圆心在原点)半径为Rm (Rm < R),圆盘固定不动,硬 ...
随机推荐
- UVA-536 Tree Recovery (二叉树遍历)
题目大意:给出对一棵二叉树先序遍历和中序遍历的顺序,找出后序遍历的顺序. 题目分析:无非就是对字符串的输出顺序做个变化,递归就行了. 代码如下: # include<iostream> # ...
- Howto: 在ArcGIS10中将地图文档(mxd文档)批量保存到之前版本
Howto: 在ArcGIS10中将地图文档(mxd文档)批量保存到之前版本 文章编号 : 38783 软件: ArcGIS - ArcEditor 10 ArcGIS - ArcInfo 10 A ...
- C# 解决datatable写入文件内存溢出问题
1.程序生成目标平台设为x64 2.文件写入后主动回收内存
- Linux DMA Engine framework(2)_功能介绍及解接口分析
http://www.wowotech.net/linux_kenrel/dma_engine_api.html 补充 http://www.zhimengzhe.com/linux/259646.h ...
- VMware 虚拟机快照、克隆、磁盘扩容
1. 快照 快照是虚拟机某个时间点上完整系统的镜像,可以在虚拟机内部通过快照文件恢复系统到之前的节点. 拍摄快照: 恢复快照: 2. 克隆 克隆是原始虚拟机全部状态的一个拷贝,是脱离原始虚拟机独立存在 ...
- IO包中的其他类总结
一.PrintStream和PrintWriter PrintStream 为其他输出流添加了功能,使它们能够方便地打印各种数据值表示形式. PrintStream 打印的所有字符都使用平台的默认字符 ...
- BZOJ3732: Network(Kruskal重构树)
题意 Link 给出一张$n$个点的无向图,每次询问两点之间边权最大值最小的路径 $n \leqslant 15000, m \leqslant 30000, k \leqslant 20000$ S ...
- c++ 声明和定义的区别
从编译原理上来说,声明是仅仅告诉编译器,有个某类型的变量会被使用,但是编译器并不会为它分配任何内存.而定义就是分配了内存. int a;在外面是作为一个语句,这就是定义,会构造对象,定义本身也是声明. ...
- IDEA java开发学习笔记
JDK8下载地址:https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 配置环境变量 ...
- 深入理解java虚拟机,内存管理部分
1,对象回收前会调用finalize()方法,尝试自救,只能调用一次 2,上面横向对比c++的析构函数,但是java有良好的内存管理,而且try/catch做得比较好 3,回收一个常量,1,对象的实例 ...