三次翻转实现数组元素的旋转

news/2024/12/22 22:16:09/

给定一个数组,将数组中的元素向右移动 k 个位置。

示例 1:

输入: [1,2,3,4,5,6,7] 和 k = 3
输出: [5,6,7,1,2,3,4]
解释:
向右旋转 1 步: [7,1,2,3,4,5,6]
向右旋转 2 步: [6,7,1,2,3,4,5]
向右旋转 3 步: [5,6,7,1,2,3,4]

示例 2:

输入: [-1,-100,3,99] 和 k = 2
输出: [3,99,-1,-100]
解释: 
向右旋转 1 步: [99,-1,-100,3]
向右旋转 2 步: [3,99,-1,-100]

三次翻转法

  1. 将数组第i ( i∈[0,n-1-k] ) 项进行对称翻转
  2. 将数组第i ( i∈[n-k,n-1] ) 项进行对称翻转
  3. 将数组第i ( i∈[0,n-1] ) 项进行对称翻转

在lua源码中lua_rotate就是用这个方式实现旋转的:

/*
** Reverse the stack segment from 'from' to 'to'
** (auxiliary to 'lua_rotate')
** Note that we move(copy) only the value inside the stack.
** (We do not move additional fields that may exist.)
*/
l_sinline void reverse (lua_State *L, StkId from, StkId to) {for (; from < to; from++, to--) {TValue temp;setobj(L, &temp, s2v(from));setobjs2s(L, from, to);setobj2s(L, to, &temp);}
}/*
** Let x = AB, where A is a prefix of length 'n'. Then,
** rotate x n == BA. But BA == (A^r . B^r)^r.
*/
LUA_API void lua_rotate (lua_State *L, int idx, int n) {StkId p, t, m;lua_lock(L);t = L->top.p - 1;  /* end of stack segment being rotated */p = index2stack(L, idx);  /* start of segment */api_check(L, (n >= 0 ? n : -n) <= (t - p + 1), "invalid 'n'");m = (n >= 0 ? t - n : p - n - 1);  /* end of prefix */reverse(L, p, m);  /* reverse the prefix with length 'n' */reverse(L, m + 1, t);  /* reverse the suffix */reverse(L, p, t);  /* reverse the entire segment */lua_unlock(L);
}


http://www.ppmy.cn/news/1557305.html

相关文章

UE5 移植Editor或Developer模块到Runtime

要将源码中的非运行时模块移植到Runtime下使用&#xff0c;个人理解就是一个解决编译报错的过程&#xff0c;先将目标模块复制到项目的source目录内&#xff0c;然后修改模块文件夹名称&#xff0c;修改模块.build.cs与文件夹名称保持一致 修改build.cs内的类名 &#xff0c;每…

8K+Red+Raw+ProRes422分享5个影视级视频素材网站

Hello&#xff0c;大家好&#xff0c;我是后期圈&#xff01; 在视频创作中&#xff0c;电影级的视频素材能够为作品增添专业质感&#xff0c;让画面更具冲击力。无论是广告、电影短片&#xff0c;还是品牌宣传&#xff0c;高质量的视频素材都是不可或缺的资源。然而&#xff…

Golong中无缓冲的 channel 和 有缓冲的 channel 的区别

在Golang中&#xff0c;channel是用于goroutine之间通信的并发原语&#xff0c;它可以是无缓冲的&#xff0c;也可以是有缓冲的。无缓冲的channel和有缓冲的channel之间存在显著的区别&#xff0c;主要体现在以下几个方面&#xff1a; 一、缓冲区大小与存储能力 无缓冲channe…

JVM和数据库面试知识点

JVM内存结构 主要有几部分&#xff1a;堆、栈、方法区和程序计数器 堆是JVM中最大的一块内存区域&#xff0c;用于存储对象实例&#xff0c;一般通过new创建的对象都存放在堆中。堆被所有的线程共享&#xff0c;但是它的访问时线程不安全的&#xff0c;通常通过锁的机制来保证线…

java——Synchronized与Lock

Synchronized和Lock都是Java中用于实现线程同步的机制&#xff0c;但它们在实现方式、使用方式以及提供的特性上存在一些显著的区别。以下是对两者的详细比较&#xff1a; 一、定义与实现方式 Synchronized 是Java语言内置的同步机制。基于监视器锁&#xff08;monitor lock&a…

flask-admin的modelview 实现list列表视图中某个列字段值翻译

背景&#xff1a; flask-admin 开发中modelview视图是非常强大的&#xff0c;但文档写的很难受&#xff0c;只能通过源码慢慢摸索学习&#xff0c;一点点记录 材料&#xff1a; 可用的flask-admin 环境 制作&#xff1a; 样例代码&#xff1a; 1、modelview 视图代码 col…

【JavaEE初阶】线程 和 thread

本节⽬标 认识多线程 掌握多线程程序的编写 掌握多线程的状态 一. 认识线程&#xff08;Thread&#xff09; 1概念 1) 线程是什么 ⼀个线程就是⼀个 "执⾏流". 每个线程之间都可以按照顺序执⾏⾃⼰的代码. 多个线程之间 "同时" 执⾏着多份代码. 还…

仓鼠身长能长到多少厘米?

仓鼠&#xff0c;作为颇受欢迎的宠物&#xff0c;其小巧玲珑的身形是吸引众多饲主的重要原因之一。那么&#xff0c;仓鼠的身长究竟能长到多少厘米呢&#xff1f;这背后其实蕴含着不少有趣的知识。 一般而言&#xff0c;常见的仓鼠品种如三线仓鼠、紫仓仓鼠等&#xff0c;成年…