线性表(a1,a2,a3,...,an)中的元素递增有序且按顺序存储于计算机内。要求设计一个算法,用最少的时间在表中查找数值为x的元素,若找到,则将其与后继元素位置相交换,若找不到,则将其插入表中并使表中元素仍递增有序。
使用二分查找
cpp
void SearchExchangeInsert(int A[],int x){
int low=0,high=n-1,mid;
while(low<=high){
mid=(low+high)/2;
if(A[mid]==x)break;
else if(A[mid]<x) low=mid+1;
else high=mid-1;
}
//交换操作
if(A[mid]==x&&mid!=n-1){
t=A[mid];
A[mid]=A[mid+1];
A[mid+1]=t;
}
if(low>high){
for(i=n-1;i>high;i--) A[i+1]=A[i];
A[i+1]=x;
}
}
data:image/s3,"s3://crabby-images/86eda/86edaa5d66d0d8785206ea1627f1f66e2a0d4eec" alt=""
data:image/s3,"s3://crabby-images/328a1/328a10aa5c32c76689742273bdb8d4cd901428e6" alt=""
data:image/s3,"s3://crabby-images/8e622/8e6224b71c0125a75b53b787e857d0224c0e47bb" alt=""
data:image/s3,"s3://crabby-images/fc513/fc513215789247d21467f51029f83a16fc7456ea" alt=""
data:image/s3,"s3://crabby-images/bc1d0/bc1d0f9e7626471459594285688c76238648d05c" alt=""