小弟有一道C语言的题不会解!希望大家来帮下忙!!

有一个已经排好序的数组。要求输入一个数,在数组中查找是否有这个数,如果有,将该数从数组中删除,要求删除后的数组仍然保持有序;如果没有,则输出“数组中没有这个数!”。请问大... 有一个已经排好序的数组。要求输入一个数,在数组中查找是否有这个数,如果有,将该数从数组中删除,要求删除后的数组仍然保持有序;如果没有,则输出“数组中没有这个数!”。

请问大家怎么解啊?
展开
 我来答
沙隆巴巴斯
2007-08-13 · 超过16用户采纳过TA的回答
知道答主
回答量:68
采纳率:0%
帮助的人:29.9万
展开全部
最基本的查找算法——折半查找。
int bsearch(int b[],int high,int key) /*b[]待查数组,high数组长度,key待查关键字*/
{
int low=0;
int mid=0;
while(low<=high)
{
mid=(low+high)/2;
if(b[mid]==key)return mid; /*查找成功,返回查询结果*/
else if(b[mid]>key)high=mid-1; /*查找前半部份*/
else low=mid+1; /*查找后半部份*/
}
return -1; /*查找失败*/
}

其他部分很简单了,自己写写看,全部要别人帮你写的话是不会有进步的,写出来有问题不懂的再提问!
leitelyaya
2007-08-13 · 超过18用户采纳过TA的回答
知道答主
回答量:49
采纳率:0%
帮助的人:49.2万
展开全部
int sernum,i,j,k,a[10];
假设已排好a
for(i=0;i<10;i++)
{if(a[i]!=sernum)
{if(i==9) printf("%s","数组中没有这个数!");}
else
{k=i;
for(j=k+1;j<10;j++)
{a[k++]=a[j];}
}}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式