亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

怎么在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

砀山县| 平潭县| 灯塔市| 牙克石市| 盐源县| 阳曲县| 三河市| 阿拉善右旗| 西昌市| 松溪县| 岳池县| 武汉市| 潜江市| 咸阳市| 孝感市| 祁连县| 梨树县| 隆子县| 盐亭县| 金乡县| 玉龙| 平乐县| 拉孜县| 武胜县| 会理县| 洛浦县| 嘉黎县| 杭州市| 开江县| 信宜市| 轮台县| 金堂县| 柞水县| 德阳市| 九龙城区| 昆山市| 旅游| 遂溪县| 河东区| 徐州市| 清镇市|