1

这种方法有什么替代方法

 tmp = c[0];
c[0] = c[1];
c[1] = c[2];
c[2] = c[3];
c[3] = tmp;

向左旋转具有 4 个元素的 char 数组

4

5 回答 5

3

使用泛型并就地旋转(感谢 Jon Skeet 的建议):

static void Rotate<T>(T[] source)
{
    var temp = source[0];
    Array.Copy(source, 1, source, 0, source.Length - 1);
    source[source.Length - 1] = temp;
}

这些应该适用于任何长度至少为 2 的数组,并且适用于任何数组。

如果性能很关键并且数组总是很小,使用这个:

static void Rotate<T>(T[] source)
{
    var temp = source[0];
    for (int i = 0; i < source.Length - 1; i++)
        source[i] = source[i + 1];
    source[source.Length - 1] = temp;
}

第一种方法对于大型数组来说是最快的,但是对于 4 个项目,这几乎与您的示例方法一样快。

于 2012-06-02T16:08:57.967 回答
1

旋转数组的另一种方法是在访问数组时旋转索引,即您正在创建一个虚拟环

int origin = someValue;
int x = c[(i + origin) % c.Length];
于 2012-06-02T16:19:14.220 回答
0

一步完成工作。

Using System.Linq;

 int[]  ar = { 1,2,3,4,5};
 int k = 1; //
 int[] ar1=  ar.Skip(k)            // Start with the last elements
             .Concat(ar.Take(k)) // Then the first elements
             .ToArray();

输出——2,3,4,5,1

于 2012-06-02T16:10:06.907 回答
0

我不确定您是在要求更有效的方法还是更简单的输入方法,但我会尝试回答您,假设您想要一种更简单的方法

所以试试:

int temp = c[0]
for(int i = 0; i < c.count; i++)
{
    if (i == (c.count - 1))
    {
        c[i] = temp;
        break;
    }
    c[i] = c[i + 1];
}
于 2012-06-02T16:10:48.527 回答
0

在 ruby​​ 中旋转阵列可以在一行中完成。

def array_rotate(arr)
    i, j = arr.length - 1, 0
    arr[j],arr[i], i, j = arr[i], arr[j], i - 1, j + 1 while(j<arr.length/2)
    puts "#{arr}"
end
于 2018-07-24T09:57:53.293 回答