字符串倒序(面试题)

来源:互联网 发布:周琦比赛数据 编辑:程序博客网 时间:2024/05/29 02:38

【问题】

以下代码是把一个字符串倒序,如“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--;}

0 0
原创粉丝点击