当前位置: 首页 > news >正文

两个网站如何做端口映射郴州网站建设软件定制开发制作

两个网站如何做端口映射,郴州网站建设软件定制开发制作,wordpress系统在线升级,cpa诱导网站怎么做🔧 常用顺序表算法与操作实现(含O(n)划分、逆置、回文、双向冒泡、二分查找、数组左移等) 本文整理了顺序表常见操作的 C/C 实现,包括划分操作、逆置与回文判断、递归二分查找、双向冒泡排序及数组循环左移,适合初学者…

🔧 常用顺序表算法与操作实现(含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);elsereturn 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 部分
}

🔚 总结

本文涵盖的内容包括:

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

  • 数组逆置与回文判断;

  • 递归二分查找;

  • 双向冒泡排序;

  • 高效数组循环左移。

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

http://www.dtcms.com/a/396246.html

相关文章:

  • 天津微网站建设智慧团建注册登录入口下载
  • 第十周SSRF漏洞
  • Pyside6 + QML - 信号与槽06 - 一个信号触发多个函数
  • html5旅游网站八大员报名入口官网
  • 海外建站平台创建网站主题在哪里
  • 太阳能电池红外异常检测+光伏巡检创新+低空经济方案
  • 建阳网站建设wzjseo苏州网站优化哪家好
  • 自动化抓取谷歌AI实战
  • seo网站优化培训多少价格部署一个网站要做哪些工作
  • 如何免费注册网站域名个人注册公司的详细步骤
  • 龙华区住房和建设局网站官网钱多网站
  • 0基础如何做网站手机主页网站推荐
  • git status突然显示很多文件改动
  • 微网站免费软件互联网服务公司有哪些
  • 做婚纱摄影网站wordpress怎样添加模板
  • 成都科技网站建设咨指数
  • 化妆品销售网站的源代码好的空间网站
  • 快速构建网站网站上内容列表怎么做
  • 网站备案注销申请表深圳网站建设有没有市场
  • 通俗易懂地解释Bradley-Terry-Luce(BTL)模型
  • 互联网营销网站建设聊城网站建设报价
  • 做网站用什么ide制作动漫的软件
  • 建设单位到江川区住房和城乡建设局网站东莞网络推广产品的公司吗
  • 网站建设与制作实训报告qq说说赞在线自助下单网站
  • AVM 全景式监控影像系统:原理、应用与未来
  • 网站建设服务方案大型门户网站建设定制
  • 栾城住房和城乡建设局网站有哪些网站可以免费做推广的
  • 单页网站模板wap做亚马逊需要的图片外链网站
  • wordpress 适合做小说站吗2023网络营销案例分析
  • 做网站用哪种语言好广西送变电建设公司网站