完全平方数【Letcode279题解】

完全平方数

这道题目是一道很好的题目,下面写两个题解 DP 和 数学的

动态规划

个人理解动态规划是这样的:把 f[i] 用 f[j] (j<i)相关的式子进行表示,那么我们就要想着去找一个比 i 小的 j 来构造 f[i]

再审视一下这道题目,我们要用完全平方数的和来表示这个数字 i i i,那么我们可以考虑到(假设)这个 i i i 有一个 完全平方数 j 2 j^2 j2 作为一部分那么我们可以写出这样的式子 i = j 2 + ( i − j 2 ) i=j^2+(i-j^2) i=j2+(i−j2)

于是乎我们就可以知道 f[i] = 1+ f[i-j*j] 了这就是这道题目的动态转移方程,具体CPP代码如下

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

int numSquares(int n){
	vector<int> msq(n+1);
	// 不考虑 0 
	for(int i=1;i<=n;i+=1){
		int t=i;
		for(int j=1;j*j<=i;j+=1){
			t=min(t,msq[i-j*j]);
		}
		msq[i]=1+t;
	}
	return msq[n];
}

int main(){
	int n;
	cin>>n;
	cout<<numSquares(n);
	return 0;
}

拉格朗日四平方和定理

借用了letcode题解的思路

如果你数学好一点,就知道 四平方定理 这个概念:四平方和定理_百度百科

由拉格朗日证明的:每一个正整数 n 都可以表示为 4 个整数的平方和,即一定存在
x = x 1 2 + x 2 2 + x 3 2 + x 4 2 x = x_1^2+x_2^2+x_3^2+x_4^2 x=x12+x22+x32+x42

根据这个定理我们就可以知道当 n = 4 k ∗ ( 8 m + 7 ) n = 4^k * (8m+7) n=4k∗(8m+7) 的时候,n只能被4个整数的平方和表示,那么接下来的情况就剩下 1,2,3个了

当 res =1的时候 n 本身就是一个完全平方数,当 res = 2 的时候可以枚举这两个整数,当res 不等于 1,2,4的时候 res 一定等于 3,由此可以得到结果

具体的Cpp语言解法如下:

cpp 复制代码
#include<iostream>
#include<cmath>
using namespace std;

bool isPerfectSquare(int n){
	int t=sqrt(n);
	return t*t==n;
}

bool isfour(int n){
	while(n%4==0){
		n/=4;
	}
	return  n%8==7;
}

int numSquare(int n){
	if(isPerfectSquare(n)){
		return 1;
	}
	if(isfour(n)){
		return 4;
	}
	for(int i=1;i*i<n;i+=1){
		int j=n-i*i;
		if(isPerfectSquare(j)){
			return 2;
		}
	}
	return 3;
}

int main(){
	int n;
	cin>>n;
	cout<<numSquare(n);
	return 0;
}
相关推荐
刀法如飞2 分钟前
Java数组去重的20种实现方式——指导AI解决不同问题的思路
java·算法·面试
沐知全栈开发3 分钟前
Scala Iterator(迭代器)
开发语言
ayqy贾杰4 分钟前
Cursor SDK发布!开发者可直接搬走其内核
前端·vue.js·面试
篮子里的玫瑰7 分钟前
Python与网络爬虫——字典与集合
开发语言·python
良木生香8 分钟前
【C++初阶】STL——Vector从入门到应用完全指南(1)
开发语言·c++·神经网络·算法·计算机视觉·自然语言处理·数据挖掘
Brilliantwxx8 分钟前
【C++】String的模拟实现(代码实现与坑点讲解)
开发语言·c++·笔记·算法
憨波个17 分钟前
【说话人日志】DOVER:diarization 输出融合算法
人工智能·算法·音频·语音识别·聚类
skilllite作者18 分钟前
Zed 1.0 编辑器深度评测与实战指南
开发语言·人工智能·windows·python·编辑器·agi
爱学习的张大19 分钟前
具身智能论文问答(四):pi0
人工智能·算法
楼田莉子21 分钟前
仿Muduo的高并发服务器:Channel模块与Poller模块
linux·服务器·c++·学习·设计模式