解题思路:
对于每个要验证的四位数abcd,我们只需要截出前两个数字ab与后两个数字cd来分别获得两个整数m,n,再将m与n相加,平方,对比原来的数字即可。
注意事项:利用sscanf和sprintf,借助字符串来截获数字。算法相对与模10除10来获得各位数字的算法更加简单。
参考代码:
#include <stdio.h> int main() { int n = 0,m = 0,i = 0;//n m分别存放要截取的两个数字,i是要验证的四位数 char s[5] = {0};//创建一个字符串用于存放四位数 for (i = 1000;i < 10000;i++) { sprintf(s, "%d", i);//把四位数i写入字符串s中 sscanf(s, "%2d", &n);//从字符串s拿出前两位数作为n sscanf(s + 2, "%2d", &m);//从字符串s拿出后两位数作为m if (i == (m + n)*(m + n))//比较 m,n和平方是否等于原数字 printf("%d ", i);//相等则输出原数字 } return 0; }
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复