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

最少的完全平方数

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

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = 10010, INF = 0x3f;
int a[N], cnt;
int dp[N], n;
void init()
{
    memset(dp, 0x3f, sizeof dp);
    for(int i = 1; i * i <= n; i ++)
    {
        a[cnt ++] = i * i;
        dp[i * i] = 1;
    }
}
int main() {
    cin >> n;
    init();
    // for(int i = 0; i <= n; i ++) cout << dp[i] << ' ';
    for(int i = 0; i < cnt; i ++)
    {
        int v = a[i];
        for(int j = v; j <= n; j ++)
        {
            dp[j] = min(dp[j], dp[j - v] + 1);
        }
    }
    cout << dp[n];
    return 0;
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

06-15 18:44
黄淮学院 Java
Lynn012:如果是居民楼还是算了吧,看着有点野呢
点赞 评论 收藏
分享
06-05 19:46
已编辑
武汉大学 后端
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-04 18:02
好不容易拿到了字节Offer,鼠鼠做后端的,但家里人觉得可能被裁员不稳定,让鼠鼠去投国企,现在好纠结到底该咋选
文档传偷助手:该投就投吧,不过建议别放弃offer 拿到手里的才是最好的
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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