字符串逆序(递归和循环)

简介: 字符串逆序(递归和循环)

题目:编写一个函数 reverse_string(char * string)


实现:将参数字符串中的字符反向排列,不是逆序打印。


要求:不能使用C函数库中的字符串操作函数。


比如:   char arr[] = "abcdef";


逆序之后数组的内容变成:fedcba


题目分析:


字符串逆序,用循环来做很简单,只需要定义两个指针,指针left放在字符串左侧,right放在最后一个有效字符位置,再交换两个指针位置上的字符,left指针往后走,right指针往前走只要两个指针没有相遇,继续交换,两个指针相遇后,逆置结束;用递归实现就相对麻烦一点,当每次传递参数的时候只有刚开始字符串中的那一个\0,在每次递归前,必须手动加上\0,才能继续用strlen计算递归传递过去的字符串长度,这一点是很难想到的。


//循环实现

#include<stdio.h>
#include<string.h>
void reverse_string(char*string)
{
  char *left = string;
  char *right = string+strlen(string) - 1;
  while (right - left > 0)
  {
    int tmp = *left;
    *left = *right;
    *right = tmp;
    left++;
    right--;
  }
}
int main()
{
  char arr[] = "abcdef";
  reverse_string(arr);
  puts(arr);
  return 0;
}

代码讲解:指针right-指针left得到的是left与right之间的元素个数,那么在编程序的时候,只需要控制left与right之间有元素的时候就交换,没有元素的时候就停止循环,交换完成。strlen函数是从传递给strlen的函数参数的地址开始一直往后找,每找到一个字符,就计数加1,知道遇见字符‘\0’为止,用于求字符串长度。


//递归实现

#include<stdio.h>
#include<string.h>
void reverse_string(char* string)
{
  int len = strlen(string);
  char tmp = *string;
  *string = *(string + len - 1);
  *(string + len - 1) = '\0';
  if (strlen(string + 1) >= 2)
    reverse_string(string+ 1);
  *(string + len - 1) = tmp;
}
int main()
{
  char arr[] = "abcdef";
  reverse_string(arr);
  puts(arr);
  return 0;
}

代码讲解:当第一次进入函数后,先将最后一个字符放在第一个字符的位置,但是不急着交换,将本该放在字符串末尾的第一个字符存起来,然后将字符串末尾置为'\0',计算从第二个字符开始,字符串的长度,如果大于1个的话,就进入递归,再重复上面的过程,递归结束后,再将存起来的字符放在交换后应该在的位置即可


总结:循环和递归还是应该尽量选择简单的,即可代码写出来,它的可读性和时间复杂度也是很重要的

相关文章
|
4月前
|
存储 算法 Java
|
1月前
|
Python
递归魔法:判断字符串是否为回文
本文介绍了如何使用递归判断一个字符串是否是回文。回文字符串是指正读和反读都相同的字符串。文章详细讲解了递归的基本思想和Python实现,并通过多个示例验证了函数的正确性。递归方法通过将大问题分解成更小的子问题,使得判断回文变得简单高效。
51 5
|
6月前
|
编译器 索引
for循环和while循环
for循环和while循环
递归和非递归分别实现求第n个斐波那契数
递归和非递归分别实现求第n个斐波那契数
70 0
|
算法 程序员 数据处理
字符串的全部子序列(递归)
在计算机科学中,子序列和子串的概念非常重要,这两个概念经常在数据处理,文本分析,编程算法等领域被广泛使用。理解子序列和子串的区别以及如何高效地处理它们对于成为一名有效的程序员是非常重要的。
204 0
|
机器学习/深度学习 算法
使用递归方法和for循环方法求阶乘
使用递归方法和for循环方法求阶乘
148 0
字符串的逆序(循环和递归两种解法)
字符串的逆序(循环和递归两种解法)
203 0
|
存储
【C】逆序字符串(俩种递归思路)
【C】逆序字符串(俩种递归思路)
95 0
【C】逆序字符串(俩种递归思路)
|
文件存储
ModelBuilder中的For循环和While循环
鸽了这么久了的ModelBuilder教程,开始恢复更新了,嘤嘤嘤 现在开始讲迭代器,迭代是指以一定的自动化程度多次重复某个过程,通常又称为循环。说的通俗点就是批量循环处理,简称批处理。
135 0