检查是否可以在C ++中从给定坐标移动到所需坐标
假设我们有两个坐标(sx,sy)和(tx,ty),我们必须检查是否可以从起点移动到终点。在这里,我们可以进行以下操作:取一个点(x,y)并将其转换为(x,x+y)或(x+y,y)。
因此,如果输入是(1、1)和(4,5),则答案将是正确的,这是因为将(1,1)移至(2,1),然后是(3,1),然后是(4),1),然后是(4,5)。
范例(C++)
让我们看下面的实现以更好地理解-
#include <bits/stdc++.h>
using namespace std;
bool solve(int sx, int sy, int tx, int ty) {
while(tx > sx && ty > sy){
if(tx > ty){
tx %= ty;
}else ty %= tx;
}
return (sx == tx && sy <= ty && (ty - sy) % tx == 0) || (sy == ty && tx >= sx && (tx - sx) % ty == 0);
}
main(){
cout << solve(1,1,4,5);
}输入
1, 1, 4, 5输出结果
1
热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志