字符串倒序(面试题)

【问题】

以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba”。请指出代码中一共有几处错误,以及出错原因。

#include<string.h>
int main()
{
  char *src="hello,world";
  char *dest=NULL;
  int len=strlen(src);
  dest=(char*)malloc(len);
  char *d=dest;
  char *s=src[len];
  while(len--!=0)
    d++=s--;
  printf("%s",dest);
  return 0;
}

【答案】

char *s=src[len];出错,改为:char *s=&src[len-1];

d++=s–  出错,改为:{*d=*s; d++; s–;}

【分析】

代码原意是定义一个指针s,指向字符串指针src的最后一个字符’d‘,初始化指针s应该指向src[len-1](字符串保存在src[0]~src[len-1])。char *s=&src[len-1];

src[len]保存的是字符串的结束符‘\0’。若改成char *s=&src[len]; 字符串指针dest中的内容将为:“\0dlrow,olle”,printf(“%s”,dest)输出时,遇到‘\0’就会终止。

指针d指向dest的第一位,指针s指向src的最后一位,将指针s指向的值赋值给指针d,然后指针s往前移一个地址,指针d往向移一个地址。这样就完成了字符串倒序的功能。因此代码应该改为:{*d=*s; d++; s–;}

    原文作者:杰Tang_fighting
    原文地址: https://blog.csdn.net/jjjcainiao/article/details/20690915
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞