C语言 将字符串逆序输出的实例
将字符串逆序输出:我先说一个我的错误代码,一开始真的不知道哪里错了,但是当时的想法是自以为是可以的,大家可以先看看我的错误代码
这个代码是错误的,正确的在最下方,不要急,我只是展示一下自己的错误,哈哈
#include#include #include #include usingnamespacestd; voidreverse(chara[]) { char*p=a,*q=a,c; inti; 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)==%ca[%d]==%c\n",*(p),i,a[i]); p--; } } intmain() { chara[100]; scanf("%s",a); reverse(a); printf("%s",a); return0; }
上面代码:我一开始想着,定义一个指针p,然后先将指针指向最后一个元素,然后慢慢往回(前面)指,再将指针p指向的值赋给a[i],i从0开始变化,这个想法其实没有错,但是却忽略了,指针只有改变地址的权利,而赋值则是将字符串完全改变了,那么指针一开始指向中间靠后的值的时候,原来a字符串里面中间靠前的字符就会改变(因为是逆着赋值的),那么到了指针p指向中间靠前的时候,p指的是已经变化过的a中的字符值啦。
那么问题来了,怎样做呢,将对称位置的字符交换即可。
下面是正确代码,比较简单,不做过多介绍啦
#include#include #include #include usingnamespacestd; voidreverse(chara[]) { char*p=a,*q=a,c; inti; while(*p!='\0') p++; p--;//此刻p指向最后一个元素 while(p>q) { c=*p; *p=*q; *q=c;//交换对称位置的字符值 p--; q++; } } intmain() { chara[100]; scanf("%s",a); reverse(a); printf("%s",a); return0; }
补充:C语言将字符串转化成整数,正序(逆序)输出
字符串转化为数字:—‘0'
数字转化为字符串:+‘0'
#include#include #include #include #include #include voidReverse(char*str)//逆序 { char*p=str; while(*p!='\0')//找到\0 { p++; } p--;//\0前一位 inttemp; while(str
以上为个人经验,希望能给大家一个参考,也希望大家多多支持毛票票。如有错误或未考虑完全的地方,望不吝赐教。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。