C语言实现数组的循环移位的方法示例

时间:2021-05-20

算法

Reverse Array (数组翻转)

code

void reverse(int array[], int left, int right){ int l, r; for (l = left, r = right; l < r; l++, r--) { array[l] = array[l] ^ array[r]; array[r] = array[l] ^ array[r]; // l ^ r ^ r = l ^ 0 = l. array[l] = array[l] ^ array[r]; // l ^ r ^ l = r ^ 0 = r; }}

上述代码通过异或运算来高效实现变量值的交换,请记住:

  • 任何数与0异或的结果都是它本身。
  • 任何数与1异或的结果都是它的相反数。

循环左移

假设我们循环左移n位,则实现的步骤是:

  • 翻转数组的前n位元素;
  • 翻转数组剩下的元素;
  • 再翻转整个数组,然后就实现了循环左移n位的功能。
  • 以上步骤的顺序也可以改为step2 -> step1 -> step3.

    code:

    reverse(array, 0, left_shift_num - 1);reverse(array, left_shift_num, array_size - 1);reverse(array, 0, array_size - 1);

    循环右移

    假设我们循环右移n位,则实现的步骤是:

  • 翻转数组的后n位元素;
  • 翻转数组剩下的元素;
  • 再翻转整个数组,然后就实现了循环右移n位的功能。
  • 以上步骤的顺序也可以改为step2 -> step1 -> step3.

    code:

    reverse(array, 0, array_size - right_shift_num - 1);reverse(array, array_size - right_shift_num, array_size - 1);reverse(array, 0, array_size -1);

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

    声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

    相关文章