解题思路和注意事项:


这道题我之前写了一篇题解的,本来是一个很简单的题,然后一个朋友的结果满屏的烫烫烫,让我帮他看看,那我正好在这里写一下,大家也可以了解一下其他方法。


首先说一下会用到的标准库函数,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;
}


点赞(39)
 

0.0分

141 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 92 条评论

Y 4月前 回复TA
@dotcpp0730766 首先,使用scanf()输入字符时是不用加地址符的;第二,第二个for循环i没有初始化,我建议你用strlen(),获取字符串长度,记得减一1,最后最后输出的是单个字符,不是字符串 应该是%c
dotcpp0730766 11月前 回复TA
#include<stdio.h>
int main()
{
    char s[100];
    int i;
    for(i=0;i<strlen(s);i++){
        scanf("%s",&s);
    }
    for(;i>=0;i--){
        printf("%d",s[i]);
    }
}
请问大家我哪个地方写错了
黄佳豪070 1年前 回复TA
@小北 #include<stdio.h> #include<string.h> void reverse_string(char*str)//反转字符串函数 {     int len=strlen(str);     for(int i=0;i<len/2;i++)     {         char temp=str[i];         str[i]=str[len-i-1];         str[len-i-1]=temp;     } } int main() {    char str[100];    printf("请输入一个字符串:");    fgets(str,sizeof(str),stdin);//从标准输出读取字符串    str[strcspn(str,"
")]=0;//去掉字符串末尾的换行符    reverse_string(str);//反转字符串    printf("反转之后的字符串:%s
",str);    return 0; }
dotcpp0633797 2年前 回复TA
@stolen #include <stdio.h> #include <stdlib.h> #include <string.h> int main() {     char str[1000];     int i, j;     gets(str);                                     //输入字符串     j = strlen(str);                             // 计算字符串的长度     for(i = j - 1 ; i >= 0 ; i --)               {         printf("%c",str[i]);                   //倒叙输出字符串     }     return 0; }
dotcpp0633797 2年前 回复TA
@stolen @995874661 i=length-1,输出arr[i]字符串后面都有一个
dotcpp0633797 2年前 回复TA
@stolen arr[length-1]
自由无畏 2年前 回复TA
@zxdf i<len 没有等号
小北 2年前 回复TA
#include<stdio.h>
#include<string.h>
int main()
{
    int n, i, j, m = 0;
    char zf1[100] = { 0 }, zf2[100] = { 0 }, zf3[5] = { 'a','e','i','o','u' };
    gets(zf1);
    n = strlen(zf1);
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < 5; j++)
        {
            if (zf1[i] == zf3[j])
            {
                zf2[m] = zf3[j];
                m++;
                break;
            }
        }
    }
    printf("%s", zf2);
    printf("\n");
    return 0;
}
thiszwiner 2年前 回复TA
你的题解re了
umbra 2年前 回复TA
@paid猫 @18773739887 有10个苹果,给他们做编号,那么,现实世界中,是1,2,3,4,5,6,7,8,9,10, 而计算机世界中,则是0,1,2,3,4,5,6,7,8,9。 数组的第1个数的下标,始终是从0开始计数的,所以,长度是10,而使用下标的时候,则要减1