C语言 将字符串逆序输出的实例

这篇文章主要介绍了C语言将字符串逆序输出的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

将字符串逆序输出:我先说一个我的错误代码,一开始真的不知道哪里错了,但是当时的想法是自以为是可以的,大家可以先看看我的错误代码

这个代码是错误的,正确的在最下方,不要急,我只是展示一下自己的错误,哈哈

 #include  #include  #include  #include  using namespace std; void reverse(char a[]) { char *p=a,*q=a,c; int i; while(*p!='\0') p++; p--;//此刻p指向最后一个元素 //  while(p>q) //  { //    c=*p; //    *p=*q; //    *q=c; //    p--; //    q++; //  } i=0; for(i=0; p>=q; i++) { a[i]=*(p);//代码就是这里出的错,在下面解释一下 printf("*(p)==%c a[%d]==%c\n",*(p),i,a[i]); p--; } } int main() { char a[100]; scanf("%s",a); reverse(a); printf("%s",a); return 0; }

上面代码:我一开始想着,定义一个指针p,然后先将指针指向最后一个元素,然后慢慢往回(前面)指,再将指针p指向的值赋给a[i],i从0开始变化,这个想法其实没有错,但是却忽略了,指针只有改变地址的权利,而赋值则是将字符串完全改变了,那么指针一开始指向中间靠后的值的时候,原来a字符串里面中间靠前的字符就会改变(因为是逆着赋值的),那么到了指针p指向中间靠前的时候,p指的是已经变化过的a中的字符值啦。

那么问题来了,怎样做呢,将对称位置的字符交换即可。

下面是正确代码,比较简单,不做过多介绍啦

 #include  #include  #include  #include  using namespace std; void reverse(char a[]) { char *p=a,*q=a,c; int i; while(*p!='\0') p++; p--;//此刻p指向最后一个元素 while(p>q) { c=*p; *p=*q; *q=c;//交换对称位置的字符值 p--; q++; } } int main() { char a[100]; scanf("%s",a); reverse(a); printf("%s",a); return 0; }

补充:C语言 将字符串转化成整数,正序(逆序)输出

字符串转化为数字:―‘0'

数字转化为字符串:+‘0'

 #include  #include  #include  #include  #include  #include  void Reverse(char *str)  //逆序 { char *p = str; while(*p != '\0')  //找到\0 { p++; } p--;  //\0前一位 int temp; while(str 

以上就是C语言 将字符串逆序输出的实例的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » C语言