码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • P1586 四方定理


    Powered by:NEFU AB-IN

    Link

    文章目录

    • P1586 四方定理
      • 题意
      • 思路
      • 代码

    P1586 四方定理

    • 题意

      四方定理是众所周知的:任意一个正整数n,可以分解为不超过四个整数的平方和
      给定的正整数n,编程统计它能分解的方案总数。

    • 思路

      d p [ i ] [ j ] dp[i][j] dp[i][j]代表i可用j个平方数组成的方案数,所以最后输出 d p [ n ] [ 1 − 4 ] dp[n][1-4] dp[n][1−4]的和即可

      由于所有数都可以使用无数次,所以采用完全背包的思想,可以理解为有1,2,3…等物品,体积为各自的平方,每个的价值都是一样的,背包体积为n,目的是问塞满背包的方案数
      得出dp方程 d p [ i ] [ j ] + = d p [ i − k ∗ k ] [ j − 1 ] dp[i][j] += dp[i - k*k][j-1] dp[i][j]+=dp[i−k∗k][j−1]

    • 代码

      /*
      * @Author: NEFU AB-IN
      * @Date: 2023-09-10 12:05:40
      * @FilePath: \Contest\C\C.cpp
      * @LastEditTime: 2023-09-16 09:18:51
      */
      #include 
      using namespace std;
      #define int long long
      #undef int
      
      #define SZ(X) ((int)(X).size())
      #define ALL(X) (X).begin(), (X).end()
      #define IOS                                                                                                            \
          ios::sync_with_stdio(false);                                                                                       \
          cin.tie(nullptr);                                                                                                  \
          cout.tie(nullptr)
      #define DEBUG(X) cout << #X << ": " << X << '\n'
      typedef pair<int, int> PII;
      
      const int N = 1e5 + 10, INF = 0x3f3f3f3f;
      
      int dp[N][5];
      
      signed main()
      {
          // freopen("Tests/input_1.txt", "r", stdin);
          IOS;
          int n = 32768, t;
          dp[0][0] = 1;
          for (int i = 1; i * i <= n; i++)
              for (int j = i * i; j <= n; j++)
                  for (int k = 1; k <= 4; k++)
                      dp[j][k] += dp[j - i * i][k - 1];
          cin >> t;
          while (t--)
          {
              int ans = 0;
              cin >> n;
              for (int i = 1; i <= 4; i++)
                  ans += dp[n][i];
              cout << ans << '\n';
          }
          return 0;
      }
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25
      • 26
      • 27
      • 28
      • 29
      • 30
      • 31
      • 32
      • 33
      • 34
      • 35
      • 36
      • 37
      • 38
      • 39
      • 40
      • 41
      • 42
      • 43
      • 44
      • 45
  • 相关阅读:
    koa框架的使用
    手动写编译器实现加减乘除运算
    c++ 学习 之 继承中 父类子类构造函数和析构函数的调用顺序
    UITesting 界面测试
    C++: multiple and virtual inheritance under the hood
    线上旧衣回收小程序,隐藏的蓝海回收市场
    Web3安全性:保护去中心化应用和用户的最佳实践
    原生JS实现拖拽排序
    [附源码]计算机毕业设计智慧园区运营管理系统Springboot程序
    汽车电子专有名词与相应技术
  • 原文地址:https://blog.csdn.net/qq_45859188/article/details/132918154
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号