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

考研中常见的算法-逆置

元素逆置

  • 概述:其实就是将 第一个元素和最后一个元素交换,第二个元素和倒数第二个元素交换,依次到中间位置。
  • 用途:可用于数组的移动,字符串反转,链表反转操作,栈和队列反转等操作。

逆置图解

代码

// 逆置元素算法
void Reverse(int R[] , int l , int r){
    // R 数组,l 左边 r 右边
    int i , j ,temp;
    for(i=l , j=r; i < j; i++,j--){					// i < j 不过数组个数是奇数还是偶数都行
        temp = R[i];
        R[i] = R[j];
        R[j] = temp;
    }
}

注意:逆置算法很简单,但是能延申其他的算法


循环移动算法

  • 考研常考的一个算法,结合逆置算法,可进行实现

循环左移(右移)算法

图解

  • 第一步:循环左移 p 个元素,就将 数组前 p 个(0~p-1)元素先进行逆置
  • 第二步:再将 数组 p-1位置 之后的(n-p)个元素进行逆置
  • 第三步:将 整个数组 整体进行逆置,即可得到 循环左移 p 个元素
代码
// 逆置元素算法
void Reverse(int R[] , int l , int r){
    // R 数组,l 左边 r 右边
    int i , j ,temp;
    for(i=l , j=r; i < j; i++,j--){
        temp = R[i];
        R[i] = R[j];
        R[j] = temp;
    }
}
// 循环左移算法
void LeftMove(int R[] , int n , int p){
    // r 数组 n 数组元素个数 p 循环左移个数
    if(p<0 || p>n){
        cout <<"ERROR"<<endl; 
    }else{
        Reverse(r , 0 , p-1);        // 先逆置前p个
        Reverse(r , p , n-1);        // 再逆置后n-p个
        Reverse(r , 0 , n-1);        // 最后再把所有的都逆置
    }
}

时间复杂度分析

①:第一行 Reverse 执行频度为:1 + (p-1-0+1)/2
②:第二行 Reverse 执行频度为:1 + (n-1-p+1)/2
③:第三行 Reverse 执行频度为:1 + (n-1-0+1)/2
f(n) = 3 + n
T(n) = O(f(n)) = O(n)
空间复杂度

由于可以看到在 整个算法中,我们只定义了变量,并未定义其他数据结构,也未使用递归,所以空间复杂度是常数级别。为 O(1)


http://www.kler.cn/a/228200.html

相关文章:

  • 12、MySQL锁相关知识
  • ThreeJs常用模块封装——加载进度条
  • ThinkPHP 8请求处理-获取请求对象与请求上下文
  • 利用 SAM2 模型探测卫星图像中的农田边界
  • BGP(1)邻居建立,路由宣告
  • 『 实战项目 』Cloud Backup System - 云备份
  • 在 iOS 上安装自定企业级应用
  • Matplotlib绘制炫酷柱状图的艺术与技巧【第60篇—python:Matplotlib绘制柱状图】
  • 2 月 3 日算法练习-数论
  • 网络安全笔记
  • 假期刷题打卡--Day23
  • 蓝桥杯Web应用开发-display属性
  • 开源计算机视觉库OpenCV详细介绍
  • Ainx框架实现 一
  • spring boot3x登录开发-上(整合jwt)
  • Bagging的随机森林;Boosting的AdaBoost和GBDT
  • 【Kotlin】Kotlin环境搭建
  • 【用Unity开发一款横板跳跃游戏部分需要学习的技术点指南】
  • Python基础学习 -05-2 基本类型
  • 【蓝桥杯冲冲冲】[NOIP2001 普及组] 装箱问题
  • JAVA——Stream流
  • 【自然语言处理】P4 神经网络基础 - 激活函数
  • 802.11 MAC帧介绍
  • 洛谷 P1359 租用游艇
  • 【Spring连载】使用Spring Data访问Redis(十三)----支持类Support Classes
  • 软件架构风格:您的系统设计指南