在給定索引範圍內刪除 C++ 陣列元素 [L – R]?


讓我們先定義刪除陣列元素的原始陣列和獨有範圍,還要找到原始的陣列長度 -

int arr[] = { 2,4,6,8,10,12,14,16,18,20};
int L = 2, R = 6;
int length = sizeof(arr) / sizeof(arr[0]);

現在我們遍歷陣列,如果索引位置 (i) 大於 L 或 R,我們增加變數 k,該變數用於一旦索引值 (i) 介於範圍 L 和 R 之間就移動陣列元素位置(刪除)。此外,給定陣列的新長度將是 k。

int k = 0;
for (int i = 0; i < length; i++) {
   if (i <= L || i >= R) {
      arr[k] = arr[i];
      k++;
   }
}

示例

讓我們看看以下實現來更好地理解如何刪除給定索引中的陣列元素

 演示

#include <iostream>
using namespace std;
int main() {
   int arr[] = { 2,4,6,8,10,12,14,16,18,20};
   int L = 2, R = 6;
   int length = sizeof(arr) / sizeof(arr[0]);
   int k = 0;
   for (int i = 0; i < length; i++) {
      if (i <= L || i >= R) {
         arr[k] = arr[i];
         k++;
      }
   }
   length=k;
   for (int i = 0; i < length; i++)
      cout << arr[i] << " ";
   return 0;
}

輸出

上面的程式碼將生成以下輸出 -

2 4 6 14 16 18 20

更新於: 16-Jan-2021

520 次瀏覽

職業快車

完成課程即可獲得認證

開始
廣告