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];
}
相关推荐
学行库小秘22 分钟前
基于门控循环单元的数据回归预测 GRU
人工智能·深度学习·神经网络·算法·回归·gru
_meow_37 分钟前
数学建模 15 逻辑回归与随机森林
算法·数学建模·逻辑回归
1白天的黑夜11 小时前
链表-24.两两交换链表中的结点-力扣(LeetCode)
数据结构·leetcode·链表
二向箔reverse1 小时前
机器学习算法核心总结
人工智能·算法·机器学习
猿究院--冯磊2 小时前
JVM垃圾收集器
java·jvm·算法
野犬寒鸦3 小时前
力扣hot100:最大子数组和的两种高效方法:前缀和与Kadane算法(53)
java·后端·算法
我家大宝最可爱3 小时前
动态规划:入门思考篇
算法·动态规划·代理模式
肉夹馍不加青椒3 小时前
第三十三天(信号量)
java·c语言·算法
古译汉书4 小时前
嵌入式-SPI番外之按钮驱动程序的编写-Day15
c语言·stm32·单片机·嵌入式硬件·mcu·算法
knd_max4 小时前
C语言:字符函数与字符串函数(1)
c语言