让我们首先定义原始数组和删除数组元素的唯一范围,并找到原始数组长度 -
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,positions(delete)一旦索引值 (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