2015-05-03 40 views
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 
+2

,就應該替換爲'(我在1:長度(LIS)-1)'和'的( i in 1:(length(lis)-1)''。 ':'運算符在減法'-'之前被計算。 – Molx

+1

雖然我們在這裏,但除非要保存其他屬性,否則矩陣可能比列表更適合多邊形數據。 – Molx

+0

問題解決。非常感謝。 –

回答

11

讓我複製你的錯誤以簡單的方式

>list1 = list() 
> list1[[0]]=list(a=c("a")) 
>Error in list1[[0]] = list(a = c("a")) : 
attempt to select less than one element 

所以,下一個問題是你在哪裏訪問0索引列表? (列表的索引從R中的1開始)

由於Molx,在以前的帖子中指出:「The:操作符在減法之前被評估 - 」。這導致了0索引列表訪問。

對於前:

> 1:10-1 
[1] 0 1 2 3 4 5 6 7 8 9 
>1:(10-1) 
[1] 1 2 3 4 5 6 7 8 9 

所以更換你的代碼下面幾行

>for(i in 1:(length(lis)-1)) 
{  
    totdis=totdis+distant(lis[[i]],lis[[i+1]]) 
} 
相關問題