#include <stdio.h>
int arr[12];//定义数组
int found(int arr[], int len, int a)
{
for (int i = 0; i < len; i++)
{
if (a == arr[i])//查找
{
return i;//如果能查找到 返回数组下标
}
}
return -1;//查找不到 返回-1
}
int main()
{
int n;//数组中元素个数
scanf("%d", &n);
for (int i = 0; i < n; i++)//将数组里输入数字
{
scanf("%d", &arr[i]);
}
int len = sizeof(arr) / sizeof(arr[0]);//测量数组长度
int x;//输入要查找的数
scanf("%d", &x);
int m = found(arr, len, x);//将函数返回值赋值给m
if (m == -1)//没找到的情况
{
printf("Not Found");
}
else
{
for (int i = m; i < n - 1; i++)//找的后将该数字从数组中删除
{
arr[i] = arr[i + 1];//从下标为m的数组开始以及以后的数组向前移一位达到删除目的
}
for (int j = 0; j < n - 1; j++)//输出删除后的数组
{
printf("%4d", arr[j]);
}
}
return 0;
}
编写程序,输入n(1<=n<=10),输入n个整数构成一个数组,输入整数x,在这个数组中查找x是否存在,如果存在,删除x,后面元素依次向前添补空位,并输出删除元
素后的数组。如果不存在,输出“Not Found”。
定义一个查找函数find(),在数组a中查找x,若找不到函数返回-1,若找到返回x的下标,函数原型如下:
int find(int a[], int n, int x);
然后在main()中,先调用函数find(),若查找失败输出“Not Found";若查找成功,则调用上一题中定义的函数del()删除该元素,再调用上一题中的PrintArr()输出删除元素后的数组内容。
输入第一行是一个正整数n(1<=n<=10);
第二行是n个整数,构成一个数组;
第三行是一个整数x,表示待查找元素。
输出删除元素后的数组,每个元素占4列,右对齐。如果不存在,输出“Not Found”。如果数组中有多个x,只删除下标最小的那个。
<span style="color:#333333"><span style="background-color:#f5f5f5">6
3 6 2 4 7 9
4
</span></span>
<span style="color:#333333"><span style="background-color:#f5f5f5"> 3 6 2 7 9</span></span>
因篇幅问题不能全部显示,请点此查看更多更全内容