一道不知出处的简单算法题解答

题目

线性表(a1,a2,…,an)中的元素递增有序且按顺序存储与数组计算机的数组a内,要求涉及算法用函数实现下列功能:

  1. 用最少的时间在表中查找值为x的元素;
  2. 如找到则将其与直接后继元素交换;
  3. 如找不到则将其插入线性表使表中元素仍然递增有序。

代码

这是一道不知道哪里的算法题。查找算法应该采用二分查找法。

#include <stdio.h>
#include <stdlib.h>
void f(int a[], int x, int n)
{
    //a为数组,x为比较目标,n为线性表长度
    int low = 0;
    int high = n - 1;
    int mid;
    while(low < high){
        mid = (low + high) / 2;
        if(a[mid] == x){
            //找到x,将其与直接后继元素交换
            if(mid == n - 1){return ;}  //x为最后一个元素,没有直接后继
            a[mid] = a[mid + 1];
            a[mid + 1] = x;
            return ;
        }
        else if(a[mid] < x)
            low = mid + 1;
        else high = mid - 1;
    }

    int i = n - 1;
    while(a[i] > x){
        a[i + 1] = a[i];
        i --;
    }
    a[i + 1] = x;
    return;
}

总结

这个代码有一定的问题,但是大体能符合要求。在测试时会有一点麻烦。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值