解题思路:

对于每个要验证的四位数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.0分

1 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论