完全平方数【Letcode279题解】

完全平方数

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

动态规划

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

再审视一下这道题目,我们要用完全平方数的和来表示这个数字 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)

于是乎我们就可以知道 fi = 1+ fi-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;
}
相关推荐
caimouse13 小时前
reactos编码规范
c语言·开发语言
小雨下雨的雨14 小时前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
xieliyu.17 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
一条小锦吕*17 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
綝~18 小时前
爬虫数据采集工程师岗位面试题
爬虫·面试·请求
CryptoPP18 小时前
快速对接东京证券交易所API数据:实战指南与代码示例
开发语言·人工智能·windows·python·信息可视化·区块链
ZC跨境爬虫18 小时前
跟着 MDN 学JavaScript day_7:数学运算与逻辑判断实战测试
开发语言·前端·javascript·学习·ecmascript
如竟没有火炬19 小时前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵
阳区欠19 小时前
【LangChain】LLM基础介绍
开发语言·python·langchain
Jinkxs19 小时前
Java 跨域14-Java 与区块链(Hyperledger)集成
java·开发语言·区块链