牛客网上有一道题目:
描述
有一个整数序列(可能有重复的整数),现删除指定的某一个整数,输出删除指定数字之后的序列,序列中未被删除数字的前后位置没有发生改变。
数据范围:序列长度和序列中的值都满足 1 \le n \le 501≤n≤50
输入描述:
第一行输入一个整数(0≤N≤50)。
第二行输入N个整数,输入用空格分隔的N个整数。
第三行输入想要进行删除的一个整数。
输出描述:
输出为一行,删除指定数字之后的序列。
分析:对于一个存放着n个元素的数组来说,如果要删除某整数,只需遍历该数组,然后将除该数字之外的元素一一输出就好了。
#include<stdio.h>
int main()
{int i=0;
int j=0;
int n=0;
int arr[50]={0};
int del=0;
scanf("%d ",&n);
for(i=0;i<n;i++)
{
scanf("%d ",&arr[i]);
}
scanf("%d ",&del);
//输入
i=0;
j=0;
for(i=0;i<n;i++)//从头到尾对整个数组进行从0到n进行数组的遍历
{
if(arr[i]!=del)//如果不是要删除的数字,那么就记下他们的位置,便于输出
{
arr[j]=arr[i];
j++;//记录下一个位置之后j++开辟下一个位置
}
}
for(i=0;i<j;i++)//此时j就是该数组中删除了某元素之后剩下的
{
printf("%d ",arr[i]);
}
return 0;
}