91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

上思县| 叶城县| 玉山县| 合阳县| 贡觉县| 城市| 芦溪县| 巴林右旗| 台中县| 玉山县| 衡东县| 龙胜| 磐石市| 湛江市| 延川县| 油尖旺区| 文成县| 钟山县| 田东县| 邵阳县| 凭祥市| 武宣县| 涪陵区| 余干县| 大庆市| 轮台县| 田阳县| 宣城市| 黄大仙区| 汉阴县| 宜丰县| 香港| 卫辉市| 安远县| 甘肃省| 长沙县| 吐鲁番市| 建阳市| 蒲城县| 达尔| 乌拉特后旗|