中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在C語言怎么實現數組循環移位

發布時間:2021-04-06 17:38:37 來源:億速云 閱讀:411 作者:Leah 欄目:編程語言

怎么在C語言怎么實現數組循環移位?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

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位,則實現的步驟是:

  1. 翻轉數組的前n位元素;

  2. 翻轉數組剩下的元素;

  3. 再翻轉整個數組,然后就實現了循環左移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位,則實現的步驟是:

  1. 翻轉數組的后n位元素;

  2. 翻轉數組剩下的元素;

  3. 再翻轉整個數組,然后就實現了循環右移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);

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

涟水县| 府谷县| 文成县| 伊川县| 湟源县| 比如县| 宁南县| 石台县| 泰来县| 天峻县| 英山县| 牟定县| 和林格尔县| 鹤山市| 资源县| 澄迈县| 大庆市| 靖江市| 绍兴市| 虹口区| 合肥市| 崇礼县| 沽源县| 都安| 芒康县| 潼南县| 麻城市| 济南市| 长春市| 富源县| 讷河市| 岚皋县| 郎溪县| 嘉峪关市| 随州市| 安图县| 乌什县| 永嘉县| 鄢陵县| 东乡族自治县| 旬邑县|