نقطه تقاطع خطوط¶
دو خط با معادلات $a_1 x + b_1 y + c_1 = 0$ و $a_2 x + b_2 y + c_2 = 0$ به شما داده شده است. باید نقطه تقاطع این دو خط را پیدا کنیم یا تشخیص دهیم که خطوط موازی هستند.
راهحل¶
اگر دو خط موازی نباشند، یکدیگر را قطع میکنند. برای یافتن نقطه تقاطع آنها، باید دستگاه معادلات خطی زیر را حل کنیم:
با استفاده از قاعده کرامر، میتوانیم بلافاصله جواب دستگاه را بنویسیم که نقطه تقاطع مورد نیاز خطوط را به ما میدهد:
اگر مخرج برابر با $0$ باشد، یعنی:
در این صورت، دستگاه یا جوابی ندارد (خطوط موازی و متمایز هستند) یا بینهایت جواب دارد (خطوط بر هم منطبق هستند). اگر بخواهیم این دو حالت را از هم تشخیص دهیم، باید بررسی کنیم که آیا ضرایب $c$ با همان نسبت ضرایب $a$ و $b$ متناسب هستند یا خیر. برای این کار کافی است دترمینانهای زیر را محاسبه کنیم، و اگر هر دو برابر با $0$ شوند، خطوط بر هم منطبق هستند:
توجه داشته باشید که یک رویکرد متفاوت برای محاسبه نقطه تقاطع در مقاله هندسه پایه توضیح داده شده است.
پیادهسازی¶
struct pt {
double x, y;
};
struct line {
double a, b, c;
};
const double EPS = 1e-9;
double det(double a, double b, double c, double d) {
return a*d - b*c;
}
bool intersect(line m, line n, pt & res) {
double zn = det(m.a, m.b, n.a, n.b);
if (abs(zn) < EPS)
return false;
res.x = -det(m.c, m.b, n.c, n.b) / zn;
res.y = -det(m.a, m.c, n.a, n.c) / zn;
return true;
}
bool parallel(line m, line n) {
return abs(det(m.a, m.b, n.a, n.b)) < EPS;
}
bool equivalent(line m, line n) {
return abs(det(m.a, m.b, n.a, n.b)) < EPS
&& abs(det(m.a, m.c, n.a, n.c)) < EPS
&& abs(det(m.b, m.c, n.b, n.c)) < EPS;
}