(C语言)数组题目:从键盘输入N个有序整数,然后在其中查找数据k,若找到,显示查找成功的信息,并将该数据删除;若没有找到,则将数据k插入这些数中,插入操作后数据仍然有序

#include <stdio.h>
#define N 8
int main()
{
	int a[N+1];
	int low,high,i,k,mid,point;
	printf("Please enter %d order data:",N);
	for(i=0;i<N;i++)
		scanf("%d",&a[i]);                        //按从小到大的顺序输入数据
	printf("Please enter the number to be located:");
	scanf("%d",&k);                                //输入要查找的数据
	low=0;
	high=N-1;
	while(low<=high)                                //二分查找
	{
		mid=(low+high)/2;
		if(a[mid]==k)
		{
			point=mid;                            //记录查找值的位置
			break;
		}
		else if(a[mid]>k) high=mid-1;
		else low=mid+1;
	}
	if(low<=high)                                //如果查找成功则删除数据
	{
		printf("The index of data is:%d, Now delete it.\n",point);  //显示查找值的下标
		for(i=point;i<N;i++)                       //删除数据
			a[i]=a[i+1];
		for(i=0;i<N-1;i++)
			printf("%5d",a[i]);
		printf("\n");
	}
	else                                        //如果查找失败则插入数据
	{
		printf("The data is not in the array! Now insert.\n ");
		i=N-1;
		while(i>=0 && a[i]>k)                    //查找并空出插入数据的位置
		{
			a[i+1]=a[i];
			i=i-1;
		}
		a[++i]=k;                                //插入数据
		for(i=0;i<N+1;i++)
			printf("%4d",a[i]);
		printf("\n");
	}
	return 0;
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值