用逆序实现左旋

本次代码的实现主要依靠于逆序

样例:abcdefg

如果要左旋3位 

abc defg

分别逆序

cba gfed

再整体逆序

defgabc

此时仍然达到了这个目的,因此可以设计一个逆序函数,使用三次来实现左旋.

首先确定主函数内容

667a599fcc144151ba133c9c04cf1823.png

 

我们先来实现一次逆序

e15c2a6fdf5c4113acd78c73f90a1a50.png

 其中,接收的是两个地址,以此确定逆序的地址区段.

再看内容,我的目的是实现第一个和最后一个字符的交换,再向中间推进.

细节:条件处没有等号是为了防止字符个数是奇数时陷入死循环.

 

确定了逆序函数,我们就应该确定实现逆序的地址区段.

首先实现左边逆序:假设我要左旋k个字符,那么我可以将第一个和第k个字符逆序,并且第一个字符的指针是arr,第k个字符的指针是arr➕k➖1

所以使用reverse函数时传入这两个指针。3327afa32e614163a4b174c648901110.png

 后面的同理.

现在开始使用!

 

 2058f2c25a6b430eace7776352da48d7.png

 可见它很好的运行了起来。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值