9
此代碼旨在計算某些給定座標的總距離,但我不知道它爲什麼不起作用。lis [[i]]中的錯誤:嘗試選擇少於一個元素
的錯誤是:Error in lis[[i]] : attempt to select less than one element.
下面是代碼:
distant<-function(a,b)
{
return(sqrt((a[1]-b[1])^2+(a[2]-b[2])^2))
}
totdistance<-function(lis)
{
totdis=0
for(i in 1:length(lis)-1)
{
totdis=totdis+distant(lis[[i]],lis[[i+1]])
}
totdis=totdis+distant(lis[[1]],lis[[length(lis)]])
return(totdis)
}
liss1<-list()
liss1[[1]]<-c(12,12)
liss1[[2]]<-c(18,23)
liss1[[4]]<-c(29,25)
liss1[[5]]<-c(31,52)
liss1[[3]]<-c(24,21)
liss1[[6]]<-c(36,43)
liss1[[7]]<-c(37,14)
liss1[[8]]<-c(42,8)
liss1[[9]]<-c(51,47)
liss1[[10]]<-c(62,53)
liss1[[11]]<-c(63,19)
liss1[[12]]<-c(69,39)
liss1[[13]]<-c(81,7)
liss1[[14]]<-c(82,18)
liss1[[15]]<-c(83,40)
liss1[[16]]<-c(88,30)
輸出:
> totdistance(liss1)
Error in lis[[i]] : attempt to select less than one element
> distant(liss1[[2]],liss1[[3]])
[1] 6.324555
,就應該替換爲'(我在1:長度(LIS)-1)'和'的( i in 1:(length(lis)-1)''。 ':'運算符在減法'-'之前被計算。 – Molx
雖然我們在這裏,但除非要保存其他屬性,否則矩陣可能比列表更適合多邊形數據。 – Molx
問題解決。非常感謝。 –