考虑以下示例,对于用户指定的奇数N = 5
,应该看到以下输出:
A = [1 4 2 5 3];
对于N = 7
:A = [1 5 2 6 3 7 4];
在奇数N
:的更一般形式中
A = [1 ceil(N/2+1) 2 ceil(N/2+2) ... N ceil(N/2)];
我讨论了这个问题
A = zeros(1, N);
a1 = 1:ceil(N/2): a2 = ceil(N/2+1):N;
j = 1; k = 1;
for i = 1:N
if rem(i, 2) ~= 0
A(i) = a1(j);
j = j+1;
else
A(i) = a2(k);
k = k+1;
end
end
我觉得有更好的方法来编码这个问题,优化和简单。如果你能引导我走向我所追求的,我将不胜感激。
一个线性解决方案:
A([1:2:N, 2:2:N]) = 1:N;
它可以被视为这些索引操作的组合:
A(1:2:N) = 1:(N+1)/2;
A(2:2:N) = (N+3)/2:N;