题解 | #最少的完全平方数#

最少的完全平方数

https://www.nowcoder.com/practice/4b2f5d4c00f44a92845bdad633965c04

package main

import (
	"fmt"
	"math"
)

func solution(n int) int {
	f := make([]int, n+1)
	for i := 1; i <= n; i++ {
		minNum := math.MaxInt
		for j := 1; j*j <= i; j++ {
			minNum = min(minNum, f[i-j*j])
		}
		f[i] = minNum + 1
	}
	return f[n]
}

func min(a, b int) int {
	if a > b {
		return b
	}
	return a
}

/*
*
输入5
输出2
说明:1 + 2*2 = 5
*/
func main() {
	var n int
	fmt.Scan(&n)
	fmt.Println(solution(n))
}

全部评论

相关推荐

测试糕手手:社会第一课,随便吹牛逼,直接说四个月,别老实。老实人只会被欺负
点赞 评论 收藏
分享
07-02 13:52
武汉大学 golang
骗你的不露头也秒
牛客87776816...:😃查看图片
点赞 评论 收藏
分享
真烦好烦真烦:豆包润色了自己没看看吗,再说了,都说豆包是愚蠢且勤快的大学生,ds才是聪明的研究生,怎么敢让豆包写论文的
你们的毕业论文什么进度了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务