移动数组以替换删除的元素
Shifting array to replace removed element
我应该得到输出 8、6。但是当此代码为 运行 时我得到 8,9。为什么我得到输出 8,6 以及如何修改代码使输出变为 8,9。
int inputarray[]={9,8,9,9,9,9,6};
int length = 7;
int value = 9;
void arrayShift(int arr[], int length, int value)
{
for(int i = 0; i<length; i++)
{
if(arr[i] == value)
{
for (int k = i; k<length ; k++)
{
arr[k] = arr[k+1];
}
arr[length-1] = 0;
}
}
}
移动数组时,您可以用其他元素的相同值替换第一个元素(包含等于 value
的数字)。在这种情况下,您需要再次对该元素重新开始迭代,例如:
void arrayShift(int arr[], int length, int value)
{
for(int i = 0; i<length; i++)
{
if(arr[i] == value)
{
for (int k = i; k<length-1 ; k++)
{
arr[k] = arr[k+1];
}
arr[length-1] = 0;
i--; // <-- this
}
}
}
您的移动算法是错误的:您未能在删除时调整 i
。此外,它的效率相当低:您可以在具有两个索引的单个循环中执行此操作 - r
用于读取,w
用于写入。当您看到要保留的值时,调整读取和写入索引。否则,仅增加阅读索引。
一旦阅读索引达到计数,写作索引将指示您还剩多少项目。您需要以某种方式 return 将其发送给调用者,否则他将不知道实际数据在哪里结束。你可以return新的长度作为你的函数的return值,或者把length
作为一个指针,并在适当的地方调整它。
int arrayShift(int arr[], int length, int value) {
int r = 0, w = 0;
for (; r != length ; r++) {
if (arr[r] != value) {
arr[w++] = arr[r];
}
}
return w;
}
您可以这样称呼它:
int inputarray[]={9,8,9,9,9,9,6};
int length = 7;
int value = 9;
int newLen = arrayShift(inputarray, length, value);
for (int i = 0 ; i != newLen ; i++) {
printf("%d ", inputarray[i]);
}
printf("\n");
我应该得到输出 8、6。但是当此代码为 运行 时我得到 8,9。为什么我得到输出 8,6 以及如何修改代码使输出变为 8,9。
int inputarray[]={9,8,9,9,9,9,6};
int length = 7;
int value = 9;
void arrayShift(int arr[], int length, int value)
{
for(int i = 0; i<length; i++)
{
if(arr[i] == value)
{
for (int k = i; k<length ; k++)
{
arr[k] = arr[k+1];
}
arr[length-1] = 0;
}
}
}
移动数组时,您可以用其他元素的相同值替换第一个元素(包含等于 value
的数字)。在这种情况下,您需要再次对该元素重新开始迭代,例如:
void arrayShift(int arr[], int length, int value)
{
for(int i = 0; i<length; i++)
{
if(arr[i] == value)
{
for (int k = i; k<length-1 ; k++)
{
arr[k] = arr[k+1];
}
arr[length-1] = 0;
i--; // <-- this
}
}
}
您的移动算法是错误的:您未能在删除时调整 i
。此外,它的效率相当低:您可以在具有两个索引的单个循环中执行此操作 - r
用于读取,w
用于写入。当您看到要保留的值时,调整读取和写入索引。否则,仅增加阅读索引。
一旦阅读索引达到计数,写作索引将指示您还剩多少项目。您需要以某种方式 return 将其发送给调用者,否则他将不知道实际数据在哪里结束。你可以return新的长度作为你的函数的return值,或者把length
作为一个指针,并在适当的地方调整它。
int arrayShift(int arr[], int length, int value) {
int r = 0, w = 0;
for (; r != length ; r++) {
if (arr[r] != value) {
arr[w++] = arr[r];
}
}
return w;
}
您可以这样称呼它:
int inputarray[]={9,8,9,9,9,9,6};
int length = 7;
int value = 9;
int newLen = arrayShift(inputarray, length, value);
for (int i = 0 ; i != newLen ; i++) {
printf("%d ", inputarray[i]);
}
printf("\n");