你的位置:首页 > 信息动态 > 新闻中心
信息动态
联系我们

函数将参数中的字符串反向排列(两种思路)

2021/11/10 6:04:41

今日笔记----将参数中的字符串反向排列,不是逆序打印

#include<stdio.h>
int my_strlen(char*str)
{
   int count = 0;
   while (*str !='\0')
   {
      count ++;
      str++;
   }
}
void reverse_string(char*str)
{
    int left =0;
    int right =my_strlen(str)-1;
    while(left<right)
   {
      char tmp = str[left];//另一种写法* char tmp =(str+left);
      str[left] = str[right];//*(str+left) = *(str+right);
      str[right] = tmp;//*(str+right) = tmp;
      left++;
      right--;
   } 

}
 int main()
{
         char arr[] ="abcde";
         reverse_string(arr);//数组名arr是数组arr首元素的地址
         printf("%s\n",arr);
         return 0;
}

练习递归 

采用递归的方法的完成

#include<stdio.h>
int my_strlen(char*str)//题目要求不能使用strlen
{
   int count = 0;
   while (*str !='\0')
   {
      count ++;
      str++;
   }
    return count;//计算字符串长度
}
void  reverse_string(char* str)
{
  char tmp = *str;
  int len = my_strlen(str);
  *str = *(str + len -1);
  *(str + len -1)='0';
  if( my_strlen(str+1)>=2)
  {
    reverse_string(str + 1);//函数递归
  }
  *(str + len -1) =tmp;
}
 int main()
{
  char arr[] = "abcdef";
  reverse_string(arr);
  printf("%s\n",arr);
       return 0;
}