C语言——判断回文数/对称数
哈喽,小伙伴们,最近在复习C语言的基础语法,从0开始,所以今天的题目比较简单,也就是我们最常见的字符串翻转问题。这道题目的作用主要是熟悉字符串的常用方法,接下来就让我们一起看看吧!
Description
读取一个字符串,字符串可能含有空格,将字符串逆转,原来的字符串与逆转后字符串相同,输出0,原字符串小于逆转后字符串输出-1,大于逆转后字符串输出1。例如输入 hello,逆转后的字符串为 olleh,因为hello 小于 olleh,所以输出-1
注意最后的判断一定要这么写,因为strcmp标准C中并不是返回-1和1,而是负值和正值
Input
输入一个字符串,例如 hello,当然输入的字符串也可能是 how are you,含有空格的字符串
Output
输出是一个整型数,如果输入的字符串是hello,那么输出的整型数为-1
Sample Input 1 Sample Output 1
hello
-1
Sample Input 2 Sample Output 2
cba
1
Sample Input 3 Sample Output 3
aba
0
首先我们来复习一下C语言中字符串常用的函数:
- gets()
读取字符串,遇到换行符才结束读入,而scanf(“%s”,&str)遇到空格就会结束一次输入,因此本道题采用gets()读取字符串。- puts()
输出字符串(遇到’\0’结束),相当于printf(“%s\n”,str);- strlen()
获取字符串实际长度(不包括’\0’)- strcmp(a,b)
比较字符串a和b的大小,返回一个整数
比较规则:
如果a>b,返回一个正数
如果a 如果a=b,返回0- strcat(a,b)
将字符串b拼接到字符串a后面,字符串a更新为拼接后的字符串
有了以上的知识,这道题做起来就很简单啦!
#include
#include
int main() {
char c[100];
char reverse[100]={0};//翻转后的数组进行初始化,为了让反转后的数组有结束符,不会输出乱码
gets(c); //读取字符并加载到字符串中,直到遇到换行符
for(int i=strlen(c)-1;i>=0;i--){ //i是字符数组c的下标
int j=strlen(c)-i-1; //j是翻转数组reverse对应的下标
reverse[j]=c[i];
}
// puts(c); //输出字符串,相当于printf("%s\n",c);
// puts(reverse);
int result= strcmp(c,reverse);
if(result<0)
printf("-1\n");
else if(result>0)
printf("1\n");
else
printf("0\n");
return 0;
}
好啦,今天的内容就到这里,如果有什么写得不好的地方,欢迎大家给我留言嘿嘿!临走之前,可以给个关注点赞评论收藏吗能让作者开心一整天哈哈!