标签:|| 记录 坐标 返回 false == 判断 nat let
在一个 XY 坐标系中有一些点,我们用数组 coordinates 来分别记录它们的坐标,其中 coordinates[i] = [x, y] 表示横坐标为 x、纵坐标为 y 的点。
请你来判断,这些点是否在该坐标系中属于同一条直线上,是则返回 true,否则请返回 false。
function checkStraightLine(coordinates) {
if(coordinates.length == 1 || coordinates.length == 2){
return true
}
let a,b;
let item0 = coordinates[0],item1 = coordinates[1];
if(item0[0] == item1[0]){
for(let i = 2;i < coordinates.length;i++){
let item = coordinates[i]
if(item[0] != item0[0]){
return false
}
}
return true
}
if(item0[1] == item1[1]){
for(let i = 2;i < coordinates.length;i++){
let item = coordinates[i]
if(item[1] != item0[1]){
return false
}
}
return true
}
a = (item1[1] - item0[1]) / (item1[0] - item0[0])
b = ((item1[1] + item0[1]) - (item1[0] + item0[0]) * a ) / 2
for(let i = 2;i < coordinates.length;i++){
let item = coordinates[i]
if(a * item[0] + b != item[1]){
return false
}
}
return true
}
Leecode提交通过
标签:|| 记录 坐标 返回 false == 判断 nat let
原文地址:https://www.cnblogs.com/zhenjianyu/p/13300366.html