leetcode279
动态规划
public class Solution
{
public int NumSquares(int n)
{
var list = new List<int>();
list.Add();
for (int i = ; i <= n; i++)
{
list.Add(i);//每一个数字,初始化为全部由1构成
}
for (int i = ; i <= n; i++)
{
for (int j = ; j * j <= i; j++)
{
var x = list[i];//当前值的构成数量,由全部是1来构成
var s = i - j * j;//减去一个平方数后的余数
var t = list[s];//余数值的构成数量
var y = t + ;//因为减过j*j,因此用余数的构成数量+1,相当于计算原值的构成数量 list[i] = Math.Min(x, y);
}
}
return list[n];
}
}
补充一个python的实现,在leetcode上会TLE,经查询发现在讨论区中也有其他的人遇到了相同的TLE问题。
应该是对python语言的判断机制有问题,这种“平台语言杀”的问题出现过多次了。
class Solution:
def numSquares(self, n: int) -> int:
dp = [] * (n + )
#初始化,所有的数字都由''组成,dp中每个元素值为组成的数量
for i in range(,n+):
dp[i] = i
for i in range(,n+):
for j in range(,int(i**0.5)+):
res = i - j * j#减去一个完全平方数后的剩余值
dp[i] = min(dp[i],dp[res] + )
return dp[n]
经过修改可以AC了,但是效率是比较低的:
class Solution:
def numSquares(self, n: int) -> int:
dp = list(range(n+1))
for i in range(,n+):
for j in range(,int(i**0.5)+):
res = i - j * j#减去一个完全平方数后的剩余值
dp[i] = min(dp[i],dp[res] + )
return dp[n]
既然python不能用dp方法提交,那就再提供一种别的思路,使用广度优先遍历(BFS):
class Solution:
def numSquares(self, n: int) -> int:
power = set()
base =
#生成符合条件的所有完全平方数,存储在power集合中
while base*base <= n:
curnum = base*base
if curnum == n:
return
power.add(curnum)
base +=
#level为返回值,表示最少的完全平方数的数量
level =
#初始目标设置为n
target = {n}
#判断条件target不为空
while len(target) > :
cur = set()
#在目标集合中循环,获得一个值
for i in target:
#在完全平方数集合中循环,获得一个值
for e in power:
#目标值 - 某个完全平方数 的差值,也是完全平方数
if i-e in power:
#返回 当前level +
return level+
#目标值 - 某个完全平方数 的差值,不是完全平方数,且大于0
if i-e > :
#将这个差值存储在‘下一层’
cur.add(i-e)
#用下一层的值更新target
target = cur
#层级+
level +=
以n=15为例,其计算流程如下:

先计算小于等于15的值中,所有的完全平方数,如上图矩形区域所示(1,4,9)三个数值。
第一层的target中的值是:(15),用15分别减去power中的数值,得到第二层;
第二层的target中的值是:(14,11,6),三个数字都不在target集合中,因此继续计算第三层,用这三个数字分别减去power中的数值,得到第三层;
第三层的target中的值是:(13, 10, 5, 10, 7, 2, 5, 2, -3),其中10,5,2出现了重复,使用set会自动去重,而-3 小于0,也会被过滤掉,
最终得到第三层的数值为:(13,10,5,7,2),这五个数字都不在power中,因此继续用这5个数字计算第四层:
当计算5时,可得到 5 - 1 = 4,而4在power中,因此结束循环。此时节点5所在的“树的高度”为3(根结点从1开始计算),因此level + 1 等于4。
最终返回4,即为所求,最终的完全平方数的组合是由线上的被减的值和叶子节点的值组成,即:[1,9,1,4]。
leetcode279的更多相关文章
- leetcode279. Perfect Squares
learn from DP class Solution { public: int numSquares(int n) { if(n<=0)return 0; int * dp = new i ...
- [Swift]LeetCode279. 完全平方数 | Perfect Squares
Given a positive integer n, find the least number of perfect square numbers (for example, 1, 4, 9, 1 ...
- leetcode279. 完全平方数
给定正整数 n,找到若干个完全平方数(比如 1, 4, 9, 16, ...)使得它们的和等于 n.你需要让组成和的完全平方数的个数最少. 示例 1: 输入: n = 12输出: 3 解释: 12 = ...
- Leetcode279. Perfect Squares完全平方数
给定正整数 n,找到若干个完全平方数(比如 1, 4, 9, 16, ...)使得它们的和等于 n.你需要让组成和的完全平方数的个数最少. 示例 1: 输入: n = 12 输出: 3 解释: 12 ...
- 图解leetcode279 —— 完全平方数
每道题附带动态示意图,提供java.python两种语言答案,力求提供leetcode最优解. 描述: 给定正整数 n,找到若干个完全平方数(比如 1, 4, 9, 16, ...)使得它们的和等于 ...
- leetcode探索高级算法
C++版 数组和字符串 正文 链表: 正文 树与图: 树: leetcode236. 二叉树的最近公共祖先 递归(先序) leetcode124二叉树最大路径和 递归 图: leetcode 547朋 ...
随机推荐
- python面向对象封装案例(附:is和==的区别)
面向对象封装案例 目标 封装 小明爱跑步 存放家具 01. 封装 封装 是面向对象编程的一大特点 面向对象编程的 第一步 —— 将 属性 和 方法 封装 到一个抽象的 类 中 外界 使用 类 创建 对 ...
- java中的线程问题(三)——继承Thread VS 实现Runnable的区别
从java的设计来看,通过继承Thread或者实现Runnable接口来创建线程本质上没有区别,从jdk帮助文档我们可以看到Thread类本身就实现了Runnable接口,如果一定要说它们有什么区别, ...
- Add和AddRange的使用
Add 是每次将单个元素添加到集合里面 AddRange可以一次性添加多个元素到集合里面 AddRange例子: public static int ExecuteCommand(st ...
- pthon入门之strip()和split()函数简单区分
小白,分享记录学习新感悟 路飞的第一次作业写一个登录的程序,作业的升级需求中有个锁文件的需求,大致上如果用户数错了密码三次将用户写到黑名单上,下次登录锁定: ok基本的要求写完,我们上代码 usern ...
- What is the CocoaUI ?
http://www.cocoaui.com/en https://github.com/ideawu/cocoaui 传统的 iOS 应用由于苹果自身的技术所限, 无法实现丰富的 UI 换皮肤(主题 ...
- JAVA高级篇(三、JVM编译机制、类加载机制)
一.类的加载过程 JVM将类的加载分为3个步骤: 1.装载(Load) 2.链接(Link) 3.初始化(Initialize) 其中 链接(Link)又分3个步骤,如下图所示: 1) 装载:查找并加 ...
- 仿QQ菜单栏:消息,电话菜单
转载自:http://blog.csdn.net/johnnyz1234/article/details/45919907 在实际项目开发使用Fragment的时候,也碰到一些异常和存在的问题,下面做 ...
- Tarjan求割点&桥
概念 1.桥:是存在于无向图中的这样的一条边,如果去掉这一条边,那么整张无向图会分为两部分,这样的一条边称为桥无向连通图中,如果删除某边后,图变成不连通,则称该边为桥. 2.割点:无向连通图中,如果删 ...
- 转载:python list和set的性能比较+两者转换
两者性能比较(转自http://www.linuxidc.com/Linux/2012-07/66404.htm) 本来是知道在Python中使用Set是比较高效,但是没想到竟然有这么大的差距: ~$ ...
- 【转载】Win10系统桌面右键新建没有Word、Excel、PPT怎么恢复?
Win10系统桌面右键新建没有Word.Excel.PPT怎么恢复? 以下正文转载至: 网址:http://www.xitongzhijia.net/xtjc/20170307/93471.html ...