Labfans是一个针对大学生、工程师和科研工作者的技术社区。 | 论坛首页 | 联系我们(Contact Us) |
![]() |
|
![]() |
#1 |
高级会员
注册日期: 2019-11-21
帖子: 3,006
声望力: 66 ![]() |
![]()
我有一个大小为(H,W)的矩阵,我需要有一个2xP输出,矩阵的所有对角相邻点,即每个(i,j)对都有[(i,j); (i-1,j-1)]和[(i,j); (i-1,j + 1)对(只有2对,而不是4对,因为我不需要重复的邻居对)。
矩阵的每个元素只是其在矩阵中的索引。 我尝试了蛮力(仅针对两个这样的邻居都存在的点): coord = reshape(1:w*h, h, w); pairs = []; for i=2:h-1 for j=2:w-1 pairs = [pairs [coord(i,j) coord(i, j); coord(i-1,j-1) coord(i-1, j+1)]]; end end 但这太慢了。在Matlab中重写该代码的智能快速方法是什么?优选地,包括仅存在这样的邻居中的一个的情况(例如,第二行和最后一列:仅左上角邻居存在而右上角不存在)。 对于h = w = 10,此代码为我提供了128对(我希望是正确的)。 更多&回答... |
![]() |
![]() |