数据结构-线性表-应用题-2.2-9

线性表(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;
  }
}
相关推荐
双叶8364 小时前
(C语言)虚数运算(结构体教程)(指针解法)(C语言教程)
c语言·开发语言·数据结构·c++·算法·microsoft
快来卷java6 小时前
MySQL篇(一):慢查询定位及索引、B树相关知识详解
java·数据结构·b树·mysql·adb
想睡hhh7 小时前
c语言数据结构——八大排序算法实现
c语言·数据结构·排序算法
月亮被咬碎成星星8 小时前
LeetCode[15]三数之和
数据结构·算法·leetcode
JCBP_9 小时前
数据结构3
服务器·c语言·数据结构·vscode
半盏茶香9 小时前
启幕数据结构算法雅航新章,穿梭C++梦幻领域的探索之旅——堆的应用之堆排、Top-K问题
java·开发语言·数据结构·c++·python·算法·链表
小竹子149 小时前
L1-1 天梯赛座位分配
数据结构·c++·算法
Phoebe鑫11 小时前
数据结构每日一题day9(顺序表)★★★★★
数据结构·算法
南玖yy12 小时前
数据结构C语言练习(栈)
c语言·数据结构·算法
MPCTHU12 小时前
二叉树、排序算法与结构图
数据结构·算法·排序算法