时间:2021-05-20
将字符串逆序输出:我先说一个我的错误代码,一开始真的不知道哪里错了,但是当时的想法是自以为是可以的,大家可以先看看我的错误代码
这个代码是错误的,正确的在最下方,不要急,我只是展示一下自己的错误,哈哈
#include <stdio.h>#include <iostream>#include <string.h>#include <math.h>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 <stdio.h>#include <iostream>#include <string.h>#include <math.h>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 <stdio.h>#include <stdlib.h>#include <vld.h>#include <assert.h>#include <ctype.h>#include <string.h> void Reverse(char *str) //逆序{ char *p = str; while(*p != '\0') //找到\0 { p++; } p--; //\0前一位 int temp; while(str < p) { temp = *str; //交换 *str = *p; *p = temp; str++; p--; }} int Myatoi(const char *str) //字符串转化为数字{ assert(*str != NULL); int sum = 0; while(isdigit(*str)) { sum = sum*10+*str-'0'; *str++; } return sum;} void Myitoa(char *str,int n) //数字转化为字符串{ assert(*str != NULL); int i = 0; do{ str[i++] = n % 10 + '0'; n /= 10; }while(n != 0); str[i] = '\0';// Reverse(str);} int main(){ char str1[100] = "1a2"; printf("num = %d\n",Myatoi(str1)); char str[100]; Myitoa(str,1235496); printf("str = %s\n",str); return 0;}以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C语言中字符串实现逆序实例详解字符串逆序和正序的实现代码:#include#include#include#include#includetyped
本文实例为大家分享了Python/C++实现字符串逆序的具体代码,供大家参考,具体内容如下题目描述:将字符串逆序输出Python实现一:借助于列表的revers
本文实例为大家分享了C++实现字符串删除字符后逆序输出的具体代码,供大家参考,具体内容如下输入若干个字符串,和一个英文字符ch。要求删除每个字符串中的字符ch(
C/C++实现递归和栈逆序字符串的实例递归函数调用模型逆序方法voidrevers(char*buf){char*p=buf;if(p==NULL){retur
c语言中puts是用来向标准输出设备(屏幕)写字符串并换行的,其中s为字符串字符(字符串数组名或字符串指针)。 C语言是一门面向过程、抽象化的通用程序设计语言