408数据结构强化(自用)

常用代码片段(持续更新)

折半查找

cs 复制代码
void SearchBinary(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;
    }

顺序表逆置

cs 复制代码
void Reverse(SqList &L){
    for(int i=0;i<L.length/2;i++){
        temp = L.data[i];
        L.data[i] = L.data[length-i-1];
        L.data[length-i-1] = temp;
    }
}

快速排序

cs 复制代码
int huafen(int A[]; int L; int R)
    int mid = A[L];
    while(L<R){
        while(L<=R&&A[R]>=mid) R--;
        A[L] = A[R];
        while(L<=R&&A[L]<=mid) L++:
        A[R] = A[L];
      }
    A[L] = mid;
    retutn L;
   }
void Qsort(int A[], int L, int R){
    if(L>=R) return;
    int M = huafen(A, L, R);
    Qsort(A, M+1, R); //右半部分快排
    Qsort(A, L, M-1); //左半部分快排
}

快速排序的划分思想

cs 复制代码
//使用划分函数找到数组中第k小的元素
int huafen(int A[]; int L; int R)
    int mid = A[L];
    while(L<R){
        while(L<=R&&A[R]>=mid) R--;
        A[L] = A[R];
        while(L<=R&&A[L]<=mid) L++:
        A[R] = A[L];
      }
    A[L] = mid;
    retutn L;
   }
int func(int A[], int n, int k){
    int L = 0, R = n-1, M = 0;
    while(1){
        M = huafen(A ,R ,L);
        if(M == k-1) break;
        else if(M > k-1) R = M-1;
        else if(M < k-1) L = m+1;
    }
    return A[k-1];
}
相关推荐
网易独家音乐人Mike Zhou19 分钟前
【Linux应用】在PC的Linux环境下通过chroot运行ARM虚拟机镜像img文件(需要依赖qemu-aarch64、不需要重新安装iso)
linux·c语言·stm32·mcu·物联网·嵌入式·iot
杨超越luckly33 分钟前
Python应用指南:使用PyKrige包实现ArcGIS的克里金插值法
python·算法·arcgis·信息可视化·克里金法
ChuHsiang36 分钟前
【C语言学习】基础知识
c语言
!执行37 分钟前
Solidity 中的`bytes`
算法·区块链·哈希算法
草莓熊Lotso1 小时前
【数据结构初阶】--双向链表(二)
c语言·数据结构·经验分享·链表·刷题
西猫雷婶2 小时前
python学智能算法(二十三)|SVM-几何距离
开发语言·人工智能·python·算法·机器学习·支持向量机
用户8685016008612 小时前
想要训练语音模型,如何从影视剧音频中获取到纯净的语音数据?
算法
WebGoC开发者3 小时前
C++题解(37) 信息学奥赛一本通1318:【例5.3】自然数的拆分
c++·算法·青少年编程·题解
Aurora_wmroy3 小时前
算法竞赛备赛——【图论】求最短路径——小结
数据结构·c++·算法·蓝桥杯·图论
우리帅杰4 小时前
【python数据结构&算法篇】基本介绍
数据结构·python·算法