解题思路:
解决此题目分为2步骤:
1、获取字符串
2、字符串逆转
注意事项:
第一步 获取用户输入字符串,以及字符串长度。
char *string=NULL;
int length=0;
scanf("%[^\n]%n",string=(char*)calloc(length+1,1),&length);
1.使用到scanf高级用法:%[^\n]、%n,使用该占位符可以获取用户输入字符串长度(不包括'\0')。
2.大部分C语言函数参数赋值顺序为从右向左。
3.变量length中是用户输入的字符串长度,string中是用户输入的字符串。
4.使用calloc动态分配length+1字节内存空间,该函数会将分配的内存空间初始化为0。
第二步 字符串翻转
void change(char src[])
{
int i;
int len=strlen(src);
for (i=0;i<len/2;i++)
{
src[i]^=src[len-i-1];
src[len-i-1]^=src[i];
src[i]^=src[len-i-1];
}
利用C语言中的按位异或运算符(^)进行数组元素交换,提高速率。
len/2提高交换效率。
参考代码:
#include<stdio.h> #include<stdlib.h> #include<string.h> void change(char src[]) { int i; int len=strlen(src); for (i=0;i<len/2;i++) { src[i]^=src[len-i-1]; src[len-i-1]^=src[i]; src[i]^=src[len-i-1]; } } int main(void) { char *string=NULL; int length=0; scanf("%[^\n]%n",string=(char*)calloc(length+1,1),&length); change(string); puts(string); return 0; }
用法:
直接输入字符串即可
输入:
123456789
输出:
987654321
欢迎交流
个人QQ:757368775
交流群:599151072
【注意】
添加好友时请注明“来自c语言网”
0.0分
39 人评分
#include<stdio.h> #include<string.h> int main() { char array[100]; gets(array); int len; len = strlen(array); for (int i = len-1; i>=0; i--) printf("%c", array[i]); return 0; } /*emmm 需要这么多代码吗?*/
#include<stdio.h> #include<string.h> int main() { char d[100],k[100] = "\0"; int b; fgets(d,99,stdin); b = strlen(d); for (int i = b - 2, j = 0; i > 0; i--, j++) k[j] = d[i]; k[b - 2] = d[0]; printf("%s", k); return 0; }
#include <stdio.h> int main() { char str[2048] = {0}; int iLen = 0; scanf("%[^\n]%n", str, &iLen); while(iLen > 0) { if(str[iLen - 1] != ' ') { printf("%c", str[iLen - 1]); } iLen--; } return 0; }
#include <stddef.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <time.h> #define p 60 //typedef sruct int main() { char a[100]={0},a1,b; for(a1=0;a1<100;a1++) scanf("%c",&a[a1]); b=a1; for(b=99;b>=0;b--) printf("%c",a[b]); return 0; } 那里不对了,我也没有空格哇
90度微笑 2019-09-15 19:28:54 |
for(a1=0;a1<100;a1++) 这个有问题 for(b=99;b>=0;b--) 会从99循环 如果字符不是99个 会出现一堆0应该
#include <stdio.h> void daoxu(int,char *p); int main(int argc,const char *argv[]) { char a[100]; int i=0; char *p=a; while((a[i]=getchar())!='\n'){ i++; } int j; j=i; daoxu(i,a); for(i=0;i<j;i++){ printf("%c",a[i]); } // printf("#"); printf("\n"); return 0; } void daoxu(int i,char *p) { // printf("p=%p\n",p); char b[100]; int j=i; for(j--;j>=0;j--){ b[j]=*p; p+=1; } p=p-i; for(j=0;j<i;j++){ *p=b[j]; // printf("*p=%c\n",*p); // printf(" p=%p\n",p); p+=1; } } 他说我这个格式错误是什么意思
柠檬树下 2020-01-22 09:52:29 |
你自定义函数里为啥要输出一些无关的东西?最后只需要主函数输出反序字符串就好了啊!
DARLING·02 2020-02-10 22:10:01 |
#include <stdio.h> void c(char *a){ if(*a!=' '){ c(a+1); printf("%c",*a); } } int main(int args,char *argv[]) { char a[100]; scanf("%s",a); fflush(stdin); c(a); return 0; }
DARLING·02 2020-02-10 22:10:11 |
这样不就行了?
#include<stdio.h> main () { char ch[999],a; int i,b; i=b=0; while(1) { scanf("%c",&ch[i]); if(ch[i]=='\n') break; i++; b++; } for(i=0;i<=b/2;i++) { a=ch[i];ch[i]=ch[b-i-1];ch[b-i-1]=a; } for(i=0;i<b;i++) printf("%c",ch[i]); return 0; } 为什么我这样交换不行。
lvxuzhou 2019-03-26 00:49:37 |
加断点调试
新手,看明白了使用 异或^来实现交换,但是,我使用dev c++来测试这个交换的速度,貌似比不上使用三个变量来交换的速度快; for( i = 0 ; i < 1000001; i ++) { c = b ; b = a ; a = c ; }//0.01068s /* for( i = 0 ; i < 1000001; i ++) { a = a^b ; b = a^b ; a = a^b ; }//0.02233s */
lvxuzhou 2019-03-24 11:39:50 |
请搞清楚a = a^b和a^ = b的区别再来分析程序。
煮酒老麦 2020-02-17 21:59:55 |
不过你这个是定义了长度为100的数组啊
机器不学习 2020-02-23 22:50:26 |
而且你这个也没有用函数
袁浩然 2020-02-29 17:30:50 |
如果是在寸土寸金的内存里,直接使用100可没有calloc好用
奥特不太快 2020-06-17 23:33:58 |
为什么每次看到这种需要动态存储的,很多人用长度100的数组就解决了,按理说不应该啊,这系统有bug
朱派金 2022-02-15 15:48:43 |
@yuanhaoran #include<stdio.h> #include<string.h> #include<stdlib.h> int main() { char* array; array = (char*)malloc(sizeof(char)); gets(array); int len; len = strlen(array); for (int i = len-1; i>=0; i--) printf("%c", array[i]); free (array); return 0; }可是这样答案是对的,但报运行错误