假设size_of_array < n,多次遍历数组元素,通常我会使用(在C++中):
for (size_t i = 0; i < n; ++i)
{
elem = arr[ i % size_of_arr ];
}
Run Code Online (Sandbox Code Playgroud)
如果arr = {1, 2, 3};,因为elem我会得到:
1 2 3 1 2 3 ...
Run Code Online (Sandbox Code Playgroud)
但是,在MATLAB/Octave索引中从1和开始:
for i = 1 : n
elem = arr( mod( i, length(arr) + 1) );
end
Run Code Online (Sandbox Code Playgroud)
所以当n == length(arr)我收到错误时:
error:arr(0):下标必须是整数1到(2 ^ 31)-1或逻辑
索引从1开始时如何完成?
在c ++中你会这样做
arr[ i % size_of_arr]
Run Code Online (Sandbox Code Playgroud)
内部索引i % size_of_arr在范围内的位置[0 size_of_arr-1]
在MATLAB中,i在范围内[1 size_of_arr],因此只需更改为
mod( i-1, numel(arr) ) + 1
Run Code Online (Sandbox Code Playgroud)
第一个bit(mod( i-1, numel(arr)))确保索引在里面[0 size_of_arr-1],你只需要添加1.