26-数据结构-线性表2

🔧 常用顺序表算法与操作实现(含O(n)划分、逆置、回文、双向冒泡、二分查找、数组左移等)

本文整理了顺序表常见操作的 C/C++ 实现,包括划分操作、逆置与回文判断、递归二分查找、双向冒泡排序及数组循环左移,适合初学者学习掌握线性表基础操作。

1️⃣ 顺序表结构定义

复制代码
#include <stdio.h>
#include <stdbool.h>
#define MAX_SIZE 100
struct SeqList {
    int data[MAX_SIZE];
    int length;
};

2️⃣ O(n) 划分算法(小于 key 的在左,大于 key 的在右)

复制代码
void spliceArray(struct SeqList *L, int key) {
    int left = 0;
    int right = L->length - 1;

    while (left <= right) {
        while (left <= right && L->data[left] < key)
            left++;
        while (left <= right && L->data[right] > key)
            right--;
        if (left <= right) {
            int tmp = L->data[left];
            L->data[left] = L->data[right];
            L->data[right] = tmp;
            left++;
            right--;
        }
    }
}

3️⃣ 数组逆置操作

复制代码
void reverseArray(int ar[], int n) {
    int i = 0, j = n - 1;
    while (i < j) {
        int tmp = ar[i];
        ar[i] = ar[j];
        ar[j] = tmp;
        i++;
        j--;
    }
}

4️⃣ 回文判断(正着读和反着读一致)

复制代码
bool isPalindrome(struct SeqList *L) {
    int i = 0, j = L->length - 1;
    while (i < j) {
        if (L->data[i] != L->data[j])
            return false;
        i++;
        j--;
    }
    return true;
}

5️⃣ 递归二分查找(需在有序表中)

复制代码
int binarySearch(struct SeqList *L, int left, int right, int target) {
    if (left > right)
        return -1;
    int mid = (left + right) / 2;
    if (L->data[mid] == target)
        return mid;
    else if (target < L->data[mid])
        return binarySearch(L, left, mid - 1, target);
    else
        return binarySearch(L, mid + 1, right, target);
}

6️⃣ 双向冒泡排序(鸡尾酒排序)

复制代码
void doubleBubbleSort(struct SeqList *L) {
    int left = 0;
    int right = L->length - 1;
    bool is_swap;

    do {
        is_swap = false;
        // 从左向右冒泡最大值
        for (int i = left; i < right; i++) {
            if (L->data[i] > L->data[i + 1]) {
                int tmp = L->data[i];
                L->data[i] = L->data[i + 1];
                L->data[i + 1] = tmp;
                is_swap = true;
            }
        }
        if (!is_swap) break;
        right--;

        is_swap = false;
        // 从右向左冒泡最小值
        for (int j = right; j > left; j--) {
            if (L->data[j] < L->data[j - 1]) {
                int tmp = L->data[j];
                L->data[j] = L->data[j - 1];
                L->data[j - 1] = tmp;
                is_swap = true;
            }
        }
        left++;
    } while (is_swap);
}

7️⃣ 数组循环左移 p 位(高效方法)

复制代码
void reverseSection(int ar[], int left, int right) {
    while (left < right) {
        int tmp = ar[left];
        ar[left] = ar[right];
        ar[right] = tmp;
        left++;
        right--;
    }
}

void rotateLeft(int ar[], int n, int p) {
    if (n <= 1 || p <= 0 || p >= n)
        return;
    p = p % n;
    reverseSection(ar, 0, n - 1);       // 整体反转
    reverseSection(ar, 0, n - p - 1);   // 反转前 n-p 部分
    reverseSection(ar, n - p, n - 1);   // 反转后 p 部分
}

🔚 总结

本文涵盖的内容包括:

  • 顺序表划分(快排思想);

  • 数组逆置与回文判断;

  • 递归二分查找;

  • 双向冒泡排序;

  • 高效数组循环左移。

这些算法是常见的基本题型,也是数据结构与算法入门的基础内容,建议每个模块都亲手敲一遍。

相关推荐
ba_pi几秒前
每天写点什么2026-03-19-Doris三种存储模型
java·数据库·mysql
程序员老乔3 分钟前
Java 新纪元 — JDK 25 + Spring Boot 4 全栈实战(二):Valhalla落地,值类型如何让电商DTO内存占用暴跌
java·spring boot·c#
SuniaWang10 分钟前
《Spring AI + 大模型全栈实战》学习手册系列· 专题二:《Milvus 向量数据库:从零开始搭建 RAG 系统的核心组件》
java·人工智能·分布式·后端·spring·架构·typescript
Klong.k10 分钟前
判断是不是素数题目
数据结构·算法
张小洛12 分钟前
Spring 常用类深度剖析(工具篇 02):ReflectionUtils——优雅操作反射的利器
java·后端·spring·工具类·spring常用类
GoodStudyAndDayDayUp29 分钟前
RUO-VUE-PRO权限关联sql
java·数据库·sql
⑩-44 分钟前
RabbitMQ 架构和工作原理?RabbitMQ 延迟队列如何实现?
java·分布式·架构·rabbitmq
子非鱼@Itfuture1 小时前
try-catch和try-with-resources区别是什么?try{}catch(){}和try(){}catch(){}有什么好处?
java·开发语言
Morwit1 小时前
*【力扣hot100】 215. 数组中的第K个最大元素
数据结构·c++·算法·leetcode·职场和发展
ab1515171 小时前
3.20二刷基础121、127,完成进阶61、62
数据结构·算法·排序算法