java用递归将数字转换字符串_将参数字符串中的字符反向排列,递归实现

这是面试中出现频率较高的问题,可以使用循环实现逆置也可以用递归的实现,首先为大家展示循环的方法,这是比较简单也更容易理解的,下面看代码

#define _CRT_SECURE_NO_WARNINGS 1

#include

#include

Reverse(char arr[],int left,int right)

{

char tmp;

while (left < right) //当数组左下标小于右下标是进行循环逆置数组

{

tmp = arr[left];

arr[left] = arr[right];

arr[right] = tmp;

left++;

right--;

}

}

int main()

{

char arr[80] = "0"; //对数组初始化

scanf("%s", &arr);

int left = 0; //将数组左下标设置为0

int right = strlen(arr) - 1;//计算出 数组的右下标

Reverse(arr,left,right);

printf("%s", arr);

system("pause");

return 0;

}

下面我们来看如何用递归的方法将字符串数组进行逆置,比较而言难以理解但只要搞清楚递归的过程便将复发的问题简单化了,通过代码来说明问题

#define _CRT_SECURE_NO_WARNINGS 1

#include

#include

Reverse(char p)

{

char tmp = 0;

int len = strlen(p);

tmp =p;

p =(p + len - 1);

(p + len - 1) = ‘ ‘; //将最后一个元素放成‘ ’是为了在下一次计算长度时更加方便,也是用递归实现的必要条件

if (strlen(p + 1)>1)//判断第一次交换完后的字符串长度是否大于1,小于1则不需要交换了

{

Reverse(p + 1);//指向下一个元素,递归

}(p + len - 1) = tmp; //此操作前是递的过程,而这一步则是归的过程

}

int main()

{

char arr[] = "0";

scanf("%s", &arr);

Reverse(arr);

printf("%s", arr);

system("pause");

return 0;

}

由此可见递归的方法虽然代码简单但是思考起来比较复杂这也是普遍现象,希望大家可以很好的理解这两份代码

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值