苛刻的字符串逆转

  2011-03-06 wcdj 问题描述:
  编写如下形式的字符串处理函数,要求将s1指向的字符串倒向复制给s2,如s1 = "hello",则使 s2 = "olleh"。且不能使用除s1和s2以外的其余任何变量。
  void ReverseStr( const char* s1 ,char* s2);
  问题来自 :讨论
  总结几种实现方法如下:
  方法一:递归 #include void ReverseStr( const char *s1 ,char *s2) { if (*s1) { ReverseStr(s1+1, s2);// recursion while(*s2) s2++; *s2 = *s1; *(s2+1) = 0; } else *s2 = 0; } int main() { char dst[128]={0}; ReverseStr("wcdj",dst);// dst == "jdcw" return 0; } 方法二:设置标记位,即添加一个哨兵 #include void ReverseStr( const char* s1 ,char* s2) { // 给s2头部加一个哨兵 *s2 = '\0'; // 令s1,s2均到达字符串最后一个字符位置 while(*s1) { ++s1,++s2; *s2 = '#';// 填充字符 } // 给s2尾部加终结符 ++s2; *s2 = '\0'; --s2; // 利用s2的头部哨兵将s2定位到头部 while(*s2) --s2; // 开始复制数据 --s1; do { *s2 = *s1; ++s2; --s1; } while(*s2); } int main() { char dst[128]={0}; ReverseStr("wcdj",dst);// dst == "jdcw" return 0; } 方法三:不使用变量使用内存,把长度存储在s2中 #include void ReverseStr( const char* s1 ,char* s2) { *((int*)s2) = 0; while (*s1) { s1++; *((int*)s2) += 1; } s1 -= *((int*)s2); s2 += *((int*)s2); *s2-- = '\0'; while (*s1) { *s2-- = *s1++; } return; } int main() { char dst[128]={0}; ReverseStr("wcdj",dst);// dst == "jdcw" return 0; } 方法四:使用异或运算交换变量 #include #include using namespace std; void ReverseStr(const char *s1 ,char *s2) { strcpy(s2,s1); while( s2 字符串常量 #include using namespace std; void reserveStr(const char* c1,char* c2) { while(*c1!='\0') ++c1; --c1; while(*c1!='\0'){ *c2=*c1; ++c2; --c1; } *c2='\0'; } int main() { //char c1[]="hello";// 这样循环不会停止 char* c1="hello";// 使用字符串常量 char c2[6]; reserveStr(c1,c2); cout<<c2<<endl; return 0; }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值