字符串倒序(面试题)

【问题】

以下代码是把一个字符串倒序,如“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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值