/*首先从键盘录入了5个数,把他们排序后输出,这已实现。
请理解我的意思~是可以选择的删除(替换)!
现在想要加上 “查找某数”和把找出的数“删除”,C语言似乎不能实现“删除”,所以我想用“替换”,
例如:查找5个数中第3个为要找的,输出的时候就把第4个的值付给第3个,第5个的值付个第4个,最后只输出4个数,而且排好的序不能乱。 */
#include"stdio.h"
#define N 5
void main()
{
int i,j;
int arr[N],bj;
printf("\n 请输入 %d 个数: \n",N);
for(i=0;i<N;i++)
{
scanf("%d",&arr[i]);
}
for(i=0;i<N;i++)
{
for(j=0;j<N-i-1;j++)
{
if(arr[j]<arr[j+1])
{
bj=arr[j+1];
arr[j+1]=arr[j];
arr[j]=bj;
}
}
}
printf("\n排序后:");
for(i=0;i<N;i++)
{
printf("%d\t",arr[i]);
}
printf("\n");
}
參考答案:#define N 5
void del(int arr[],int len,int n)
{
int i=0;
while(i<len)
{
if(arr[i]==n)
{
printf("Found element %d\n",n);
for(int j=i;j<len-1;j++)
{
arr[j]=arr[j+1];
}
arr[len-1]='\0';
return;
}
i++;
}
printf("Element %d not found\n",n);
}
void main()
{
int i,j;
int arr[N],bj;
printf("\n 请输入 %d 个数: \n",N);
for(i=0;i<N;i++)
{
scanf("%d",&arr[i]);
}
for(i=0;i<N;i++)
{
for(j=0;j<N-i-1;j++)
{
if(arr[j]<arr[j+1])
{
bj=arr[j+1];
arr[j+1]=arr[j];
arr[j]=bj;
}
}
}
printf("\n排序后:");
for(i=0;i<N;i++)
{
printf("%d\t",arr[i]);
}
printf("\n");
int data;
printf("Input the data you want to delete");
scanf("%d",&data);
del(arr,N,data);
printf("\nAfter Delete:");
for(i=0;i<N-1;i++)
{
printf("%d\t",arr[i]);
}
printf("\n");
}