C语言数组中删除指定数字

首先要注意的是指定数字在数组中会有多次出现,所以一定要从第一个遍历到最后一个,不能找到一个就跳出循环。常规思路就是找到一个就把后面的整体向前覆盖,重复操作,直到遍历完整个数组。为了降低时间复杂度,我这里提供类似左右指针的操作方法。

假设要删除的数字是7

C语言数组中删除指定数字_第1张图片

 

#define _CRT_SECURE_NO_WARNINGS 1
#include
#include
int main()
{
	int n = 0;
	int a = 0;
	int j = 0;
	scanf("%d", &n);
	int b = n;
	int* p = (int*)malloc(4 * n);
	for (int i = 0; i < n; i++)
	{
		scanf("%d", &p[i]);
	}
	scanf("%d", &a);
	for (int i = 0; i < n; i++)
	{
		if (p[i] == a)
		{
			b--;
			continue;
		}
		else
		{
			p[j] = p[i];
			j++;
		}
	}
	for (int i = 0; i < b; i++)
	{
		printf("%d ", p[i]);
	}
	system("pause");
	return 0;
}

C语言数组中删除指定数字_第2张图片

 

你可能感兴趣的:(数据结构)