我正在尝试编写一个遍历数组的函数,当它找到某种类型的值时,它将向右移动定义数量的位置。
我知道如何通过临时存储一个值来移动元素,将右侧元素向左移动,然后将临时值写入正确的位置。
我正在苦苦挣扎的一点是,如果某个字符出现在数组的末尾附近,我需要它环绕并从数组的开头继续,所以是循环的。
例如,一个数组将大写字母向右移动 3 位,特殊字符向左移动 1 位:
{ M, y, N, a, m, e, P} becomes...
{ y, M, P, a, N, m, e}
要将 8 的元素移动到下面的 3 个位置,但这仅适用于 8 出现在数组末尾的 3 个元素之前并且不会环绕的情况。
输入数组:
{0, 1, 2, 3, 4, 5, 6, 7, **8**, 9}
所需的输出:
{0, **8**, 1, 2, 3, 4, 5, 6, 7, 9}
int[] array = new int[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
for (int i = array.Length - 1; i >= 0; i--)
{
if (array[i] == 8)
{
int temp = array[i];
int j = 0;
for (j = i; j < i + 3; j++)
{
array[j] = array[j + 1];
}
array[j] = temp;
}
}