解题思路和注意事项:
这道题我之前写了一篇题解的,本来是一个很简单的题,然后一个朋友的结果满屏的烫烫烫,让我帮他看看,那我正好在这里写一下,大家也可以了解一下其他方法。
首先说一下会用到的标准库函数,gets(),puts(),strlen(),前两个是在头文件stdio.h中,后一个是在string.h里,用法如下:
1、gets():与scanf("%s",s)相似,但不完全相同,使用scanf("%s",s) 函数输入字符串时存在一个问题,就是如果输入了空格会认为字符串结束,空格后的字符将作为下一个输入项处理,但gets()函数将接收输入的整个字符串直到遇到换行为止。
2、puts(): puts 和 printf的用法一样,puts()函数的作用与语句“printf("%s\n",s);的作用相同。注意:puts在输出字 符串后会自动输出一个回车符。
3、strlen():使用格式strlen(s)。返回s的长度,不包括结束符NULL。
其次我们的思路是申明一个exchange()函数用来做逆序,方法是:
b数组的第一个元素存储a数组的最后一个元素。l是数组a的长度,具体看代码,一目了然。
注:在将数组a的值赋给b数组之后,需要加一个b[j] = '\0'语句,不然会很烫的!这是因为我在将a的值赋给b的过程中并非是所有元素都有赋值,并且末尾没有结束符,而puts()输出字符串时要遇到'\0’也就是字符结束符才停止,所以要加上一句b[j] = '\0';
参考代码:
#include<stdio.h> #include<string.h> int exchange(char a[],char b[]) { int i,l,j = 0; l = strlen(a); for(i=l-1; i>=0; i--){ b[j] = a[i]; j++; } b[j] = '\0'; //给末尾加上结束符。 return 0; } int main() { char a[1000],b[1000]; gets(a); exchange(a,b); puts(b); return 0; }
0.0分
180 人评分
#include <stdio.h> #include <string.h> void Reverse(char a[]) { int i, len; len = strlen(a); for(i = len - 1; i >= 0; i--) printf("%c", a[i]); printf("\0"); } int main(void) { char str[50]; gets(str); Reverse(str); return 0; } 有没有大神帮我看下哪里出现了问题, 一直提示格式错误QAQ
#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; } 帮看下为什么提交不得,谢谢了!
#include<stdio.h> #include<string.h> int f(char * p,int l) { int a[l]; for(int i=0;i<l;i++) { a[i]=*(p+l-1); p--; } for(int i=0;i<l;i++) { *(p+l)=a[i]; p++; } return 0; } int main() { char a[80]; gets(a); f(a,strlen(a)); puts(a); return 0; }
void reverse(char ch[],int n) { int x; char mid[100]; for (x = n; x > n/2; x--) { mid[x] = ch[n - x]; ch[n - x] = ch[x]; ch[x] = mid[x]; } } int main() { char ch[100]; int n,t; for (n = 0; n < 100; n++) { ch[n] = getchar(); if (ch[n] == '\n') { break; } } reverse(ch,n-1); for ( t = 0; t < n; t++) { printf("%c", ch[t]); } } 为啥是错误百分之五十?求帮帮忙啊!!!
<pre class="brush:cpp;toolbar:false"> #include<stdio.h> #include<string.h> int fun(char a[100]) { int i,k=0; char t; for(i=(strlen(a))/2;i>=1;i--)//取长度-1的一半 { t=a[k];//第1个字符给t a[k]=a[strlen(a)-1-k];//最后1个字符给第1个字符 a[strlen(a)-1-k]=t;//t保存的第1个字符给最后1个位置 k++; } return 0; } int main() { char a[100]; gets(a); fun(a); printf("%s\n",a); return 0; }</pre>
xiaohouge 2019-03-03 10:26:34 |
怎么有html代码了。。。浏览器插件。。。
#include <stdio.h> //为什么说格式错误50% int getline ( char s[], int lim ){ int c; int i; i=0; for(i=0; ((c=getchar()) != EOF) && c!='\n' ; i++){ s[i]=c; } if(c== '\n') { s[i] = c; i++; } s[i]='\0'; return i; } char reserve (char to[],char from[],int lim){ int i=0; for(i = 0 ; i<lim ; i++){ to[i] = from [lim -i-1]; } to[i]='\0'; return *to; } int main() { int len; int c; char line[1000]; len = getline ( line , 1000 ) ; int max =len ; char reserved[max]; if ( len > 0){ reserve (reserved , line,len ); } printf("%s
C语言程序设计教程(第三版)课后习题11.5 (C语言代码)浏览:932 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:1000 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:485 |
【排队买票】 (C语言代码)浏览:944 |
【金明的预算方案】 (C++代码)浏览:996 |
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:683 |
幸运数 (C++代码)浏览:1309 |
1051(奇了怪了)浏览:747 |
C二级辅导-阶乘数列 (C语言代码)浏览:583 |
2005年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:636 |