数据结构-线性表-应用题-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;
  }
}
相关推荐
浅念-11 分钟前
Linux 开发环境与工具链
linux·运维·服务器·数据结构·c++·经验分享
x_xbx4 小时前
LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
菜菜小狗的学习笔记6 小时前
剑指Offer算法题(九)搜索
数据结构·算法·深度优先
愣头不青8 小时前
96.不同的二叉搜索树
数据结构·算法·leetcode
⁤⁢初遇8 小时前
C语言数据结构---树
数据结构
m0_734998018 小时前
Day 26
数据结构·c++·算法
励志的小陈10 小时前
复杂度算法题——旋转数组(三种思路)
c语言·数据结构·算法
Sirens.10 小时前
对顺序表以及双向链表的理解
数据结构·链表
㓗冽10 小时前
2026.03.27(第三天)
数据结构·c++·算法
七七肆十九11 小时前
PTA 7-38 数列求和-加强版
数据结构·算法