左右旋对比

article/2025/9/28 18:56:59

目录

前言

一,逆置法

1.1逆置思路

1.2逆置实现

二,左旋和右旋对比

                                         右旋代码分析

                                             特点对比


前言

之前在up主的博客里面已经有过了对于左旋的三种实现方法。当然,如果我们考虑到时间复杂度的问题,那么我们只要一种方法,那就是逆置法。那么接下来我们分别对于左旋和右旋的中心思想做一个比较。

tips:本文对于新手友好,如只是需要分辨左右旋的同学,可直接跳到最后特点辨析部分。

一,逆置法

1.1逆置思路

我们知道,逆置法主要思想就是,将要逆置的个数之前的一组数逆置,然后再将该数之后的一组数逆置,最后,在将所有数全部逆置。

我们以左旋为例,为大家介绍逆置法。如图所示:

 

如上图所示,k 表示要左旋的次数,蓝色框框起来的表示需要逆置的第一部分;然后我们再将 K 后面的紫色框框起来的部分进行逆置;最后再将整体绿色框的部分进行逆置,这样就完成了我们对于整个数组的逆置。

1.2逆置实现

我们以 K 之前的蓝色框部分为例。

 

首先我们需要两个指针,分别指向该部分的首尾两个元素;

其次,将首尾指针指向的两元素进行交换,然后两指针分别往中间移动,直到两个指针指向同一位置或者begin指针大于end指针。此时该部分逆置结束。

二,左旋和右旋对比

那么我们了解了逆置法以及其实现原理,我们就分别对于左旋和右旋的一个案例进行分析。

                                         右旋代码分析

void revrse(int* arr, int begin, int end)
{assert(arr);while (begin < end){int tmp = arr[begin];arr[begin] = arr[end];arr[end] = tmp;begin++;end--;}
}
void rotate(int* nums, int numsSize, int k) {assert(nums);k = k % numsSize;revrse(nums, 0, (numsSize - k) - 1);revrse(nums, numsSize - k, numsSize - 1);revrse(nums, 0, numsSize - 1);
}

该段代码即是右旋部分的实现代码,对于 revrse 部分的旋转部分我们在上面已经做了分析,所以这里我们主要分析 rotate 部分的思想实现部分

首先我们需要对旋转次数取模,因为旋转次数应该在数组元素个数范围内。

其次,因为数组是通过下标访问的,所以我们需要对元素个数减 1。 

以上部分基本都是一样的,所以我们不做过多解释,如有小伙伴有问题,还请参考另一篇文章哦!字符串左旋?你,值得拥有_憨憨二号耶!的博客-CSDN博客 

                                             特点对比

那么我们知道,对于右旋来说,如果想旋转三次,那么就需要从右边往左数三个数,然后,将整个数组分为两个部分。如下图所示:

 而对于左旋,我们知道是从左边往右边数的。如下图所示:

那么,通过这样分隔之后,对于rotate部分的思想实现代码,传递的首尾的参数应该是不一样的,同样都是旋转三次,但是因为左右的不同,导致旋转结果的不同。那么看到小伙伴们是不是对于左右旋有一个更清楚的认识呢?

好的,本文到此就是结束啦,如有需要,还请留言评论哦!


http://chatgpt.dhexx.cn/article/txYLHi6y.shtml

相关文章

平衡二叉树的左旋右旋详解 看不懂你打我

平衡二叉树的左旋右旋 看不懂你打我 左旋右旋的操作为什么要左旋右旋左旋右旋能保持排序二叉排序树的性质吗下次写平衡二叉树的LL、RR、LR、RL。 左旋右旋的操作 1.左旋&#xff1a;对X节点左旋&#xff0c;即以X的右孩子Y为轴&#xff0c;将X节点转下来&#xff0c;变为Y的左…

二叉树的旋转,左旋和右旋

在AVLTree中经常会有以某个节点为点对子树进行旋转的操作&#xff0c;今天就和大家分享一下什么是二叉树的旋转。 这是一棵二叉树&#xff0c;上图称为图一。 将图一中的树以1为旋转点进行左旋后得到图二&#xff1a; 将图一中的树以1为旋转点进行右旋旋后得到图三&#xff1…

day062:平衡二叉树——左旋、右旋

二叉树、平衡二叉树的介绍&#xff1a;day061&#xff1a;二叉树、二叉查找树、平衡二叉树_ZQyyds&#xff1a;&#xff09;的博客-CSDN博客 目录 一、平衡二叉树的左旋 1.为什么要左旋、右旋&#xff1f; 2.什么是左旋&#xff1f; 3.图解 二、平衡二叉树的右旋 1.什么是…

大型json文件格式化【超简单】

问题 遇到了一个很大的JSON文件&#xff08;约4M&#xff09;&#xff0c;想格式化查看&#xff0c;在线json工具会直接崩溃&#xff0c;网上其他同学说的python方法之类的我也都实验失败&#xff0c;但是发现了vs code中一个超强的代码格式化 解决1&#xff08;2019.2.10更…

Unity存档系统——Json格式的文件

实例场景 点击Save按钮后&#xff0c;查看保存的文件 点击Load按钮后加载文档数据 Json介绍https://www.json.org/json-zh.htmlUnity中自带的JsonUtility可以将可序列化对象与Json格式相互转换。 将对象转为可序列化对象需要添加[SerializeField]&#xff0c;且为public&#…

将json文件格式转化成Excel表格形式

在程序员的工作中&#xff0c;经常有产品或者运营部门的小姐姐需要数据&#xff0c;由于不懂技术&#xff0c;就需要我们将Json格式的数据转换成Excel文档提供给她们进行数据分析。 本文就介绍一个非常简单方便的方法 1.运用的是Excel表格自带的功能 首先打开Excel文件 点击插…

js导出JSON格式文件

在src目录下新建tools文件价&#xff0c;在tools文件中新建index.js(文件内名字随意) 在index.js文件中 const Tools {// 导出文件exportJson(name, data) {let blob new Blob([data]); // 创建 blob 对象let link document.createElement("a");link.href URL.…

json文件

认识一下 json文件 直接使用记事本打开&#xff1a;例如猫狗二分类 一般都使用类似字典的方式存储&#xff0c;但和字典不同&#xff0c;无论是键还是值&#xff0c;都要加上双引号。 json文件的读取与写入 import jsondata {"a":"1","b":&q…

JSON格式校验工具

经常用ApiPost 和 Postman 测试自己写的接口的话&#xff0c;有时会不小心写错传进去的json对象&#xff0c;我们可以用json格式检验工具去检查一下自己json格式。 在线工具&#xff1a;在线 JSON 工具&#xff0c;JSON 校验/格式化/压缩/工具 - 在线工具-wetools.com微工具

python文件处理——JSON格式文件

python文件处理——JSON格式文件 hello&#xff01;我是wakeyo_J&#xff0c;每天一个konwledge point&#xff0c;一起学python&#xff0c;让技术无限发散。 JSON格式文件 python文件处理——JSON格式文件1. JSON格式1.1 JSON常用的两种结构数据类型1.2 JSON数据与python数据…

json文件格式详解

json文件格式详解 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式&a…

json文件格式转换为png文件格式

话不多少&#xff0c;直接上代码&#xff0c;更换源目录和目标目录即可 1、导入库 import cv2 import numpy as np import os import shutil import matplotlib.pyplot as plt 2、设置源目录/输出目录 json_dir G:/json_filedir/ #json文件所在文件夹(注&#xff1a;文…

Notepad++工具 格式化Json文件格式

简介&#xff1a; Notepad是常用的文件查看工具&#xff0c;在查看json的文件时&#xff0c;如果json文件的格式不符合正常的可视格式&#xff0c;那就需要格式化json文件&#xff0c;使之符合我们的可视化需求。 流程&#xff1a; 首先打开Notepad 打开Plugins 在搜索框中填入…

JSON 文件存储

&#x1f4cb; 个人简介 &#x1f496; 作者简介&#xff1a;大家好&#xff0c;我是W_chuanqi&#xff0c;一个编程爱好者 &#x1f4d9; 个人主页&#xff1a;W_chaunqi &#x1f600; 支持我&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f4ac; 愿你我共…

JSON 文件格式

最近的开发中用到了JSON文件&#xff0c;JSON是网络中比较常用的数据交换格式&#xff0c;Google chrome 浏览器的书签文件就采用了JSON格式。 以下是官方网站对JSON的介绍&#xff0c;URL&#xff1a;http://json.org//json-zh.html JSON(JavaScript Object Notation) 是一种…

json文件格式标准

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition – December 1999的一个子集。 JSON采用完全独立于语言的文本格式&#xff0c;但是也使…

Json文件格式化方法

1. JSON 是一种存储和交换数据的语法 当数据在浏览器与服务器之间进行交换时&#xff0c;这些数据只能是文本。 JSON 属于文本&#xff0c;并且我们能够把任何 JavaScript 对象转换为 JSON&#xff0c;然后将 JSON 发送到服务器。 我们也能把从服务器接收到的任何 JSON 转换…

JSON的三种格式

JSON的三种格式 一、 JSON的全称 JSON的全称是JavaScript Object Notation 二、为什么需要JSON JSON有三种格式&#xff0c;每一种写法都和JS中的数据类型很像&#xff0c;可以很轻松的和JS中的数据类型互相转换 三、JSON的三种格式 &#xff08;一&#xff09;、简单值的形式…

JSON文件格式

前言&#xff1a; JSON是个什么东东&#xff1f; JSON 指的是 JavaScript 对象表示法&#xff08;JavaScript Object Notation&#xff09; JSON 是轻量级的文本数据交换格式&#xff0c;是存储和交换文本信息的语法。类似 XML。 JSON 比 XML 更小、更快&#xff0c;更易解析。…