C++ 程序,用来找出两条直线上不在同一处的两个点


假设我们有两个区间 (l1, r1), (l2, r2) 表示 x 轴上的两条直线。l1 < r1 且 l2 < r2。这些线段可能相交、重叠或彼此重合。我们必须找到两个数字 a 和 b,使得 a 在区间 (l1, r1) 中,b 在 (l2, r2) 中,并且 a 和 b 是不同的。

因此,如果输入类似 l1 = 2; r1 = 6; l2 = 3; r2 = 4,则输出将为 a = 3,b = 4,其他答案也是可能的。

步骤

为了解决此问题,我们将按照以下步骤进行 −

if l1 is same as l2, then:
   (increase l1 by 1)
return l1 and l2

示例

让我们看看下面的实现,以便更好地理解 −

#include <bits/stdc++.h>
using namespace std;

void solve(int l1, int r1, int l2, int r2) {
   if (l1 == l2)
      l1++;
   cout << l1 << ", " << l2;
}
int main() {
   int l1 = 2;
   int r1 = 6;
   int l2 = 3;
   int r2 = 4;
   solve(l1, r1, l2, r2);
}

输入

2, 6, 3, 4

输出

2, 3

更新于:03-03-2022

286 次浏览

开启你的 职业生涯

通过完成课程获得认证

开始
广告