上海计算机学会2021年8月月赛C++丙组T3四方定理

题目背景

四方定理是数论中著名的一个定理,指任意一个自然数都可以拆成四个自然数的平方之和。例如:

25=12+22+22+4225=12+22+22+42

对2525来说,还有其他方案:

25=02+02+32+4225=02+02+32+42

以及

25=02+02+02+5225=02+02+02+52

题目描述

给定一个自然数 n,请输出 n 的所有四平方拆分方案。

输入格式

单个整数:表示 n。

输出格式

若干行:每行四个由小到大排列的自然数,表示一种拆分方案。如果有多种方案,先输出首项较小的方案,对于首项相同的方案,先输出第二项较小的方案,其他情况以此类推。

数据范围

0≤n≤50,000。

样例数据

输入:

25

输出:

0 0 0 5

0 0 3 4

1 2 2 4

解析:

本题关键点:循环的最大值不要定义为输入的数字n,开一个平方,降低时间复杂度; 然后分成四个for循环解题,代码如下。

cpp 复制代码
#include <iostream>
#include <cmath>
using namespace std;
int main(){
	int a,b,c,d;
	long n,t;
	cin>>n;
	t=int(sqrt(n));
	for(a=0;a<=t;a++)
		for(b=a;b<=t;b++)
			for(c=b;c<=t;c++)
				for(d=c;d<=t;d++)
				{
					if(a*a+b*b+c*c+d*d==n)
						cout<<a<<" "<<b<<" "<<c<<" "<<d<<endl;			
				}			
	return 0;
}
相关推荐
她说彩礼65万2 分钟前
C语言 函数指针
c语言·开发语言·算法
王老师青少年编程3 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:纪念品分组
c++·算法·贪心·csp·信奥赛·排序贪心·纪念品分组
tankeven3 分钟前
C++ 学习杂记03:std::string 类
c++
贾斯汀玛尔斯6 分钟前
每天学一个算法--贪心算法(Greedy Algorithm)
算法·贪心算法
前端摸鱼匠7 分钟前
【AI大模型春招面试题24】什么是“注意力分数”?如何计算?其大小反映了什么?
人工智能·算法·ai·面试·大模型·求职招聘
MicroTech20257 分钟前
融合残差结构的量子电路算法:MLGO微算法科技拓展量子机器学习频谱边界
科技·算法·机器学习
H_BB8 分钟前
动态规划详解
c++·算法·动态规划
算法鑫探8 分钟前
贪心算法(C 语言实现)及经典应用
c语言·数据结构·算法·贪心算法
始三角龙9 分钟前
LeetCode hoot 100 -- 和为K的子数组
算法·leetcode·职场和发展
ccice0111 分钟前
python爬虫——爬取全年天气数据并做可视化分析
开发语言·爬虫·python