字符串反转的各种方法

举报
悦来客栈的老板 发表于 2020/12/30 00:24:44 2020/12/30
【摘要】 版本1void reverse(char *str){ int i; int j = strlen(str); char temp; for (i=0; i<j;i++,j--) { temp = str[i]; str[i] = str[j-1]; str[j-1] = temp; }} 版本2void reverse(char *str...

      版本1
      void reverse(char *str)
      {
     	int i;
     	int j = strlen(str);
     	char temp;
     	for (i=0; i<j;i++,j--)
      	{
      		temp = str[i];
      		str[i] = str[j-1];
      		str[j-1] = temp;
      	}
      }
  
 





      版本2
      void reverse(char *str)
      {
     	int i;
     	int j = strlen(str);
     	char temp;
     	for (i=0; i<j/2;i++)
      	{
      		temp = str[i];
      		str[i] = str[j-i-1];
      		str[j-i-1] = temp;
      	}
      }
  
 


      版本3
      void reverse(char *str)
      {
     	char temp;
     	char *last_char;
     	for (last_char = str; *last_char != '\0'; last_char++)
      		;
      	last_char--;
     	while (str < last_char)
      	{
      		temp = *str;
      		*str++ = *last_char;
      		*last_char-- = temp;
      	}
      }
  
 



      版本4
      void reverse(char *str)
      {
     	char temp;
     	char *last_char;
     	for (last_char = str; *last_char != '\0'; last_char++)
      		;
      	last_char--;
     	while(str<last_char)
      	{
      		*str = *str ^ *last_char;
      		*last_char = *str ^ *last_char;
      		*str = *str ^ *last_char;;
      		str++;
      		last_char--;
      	}
      }
  
 



文章来源: blog.csdn.net,作者:悦来客栈的老板,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/qq523176585/article/details/11779505

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。