codeforces A -Cut Ribbon

思路

  • 基础 d p dp dp , d p i , j dp_{i,j} dpi,j 表示长度为 i i i , p i e c e piece piece 为 j j j 的数量。题目范围 4000 4000 4000 常规定义可能会 M E L MEL MEL ,所以第二维为不同的 p i e c e piece piece 的个数。
  • 枚举不同的 p i e c e s pieces pieces 长度。
  • 方程: d p i , j = d p i − l e n j , j + 1 / 0 dp_{i,j}=dp_{i-len_j,j}+1/0 dpi,j=dpi−lenj,j+1/0 。(是当前枚举长度则为 1 1 1 )

Think Twice, Code Once

cpp 复制代码
signed main() {

    int T = 1;
//    T = read();
    while (T--) {
        int n = read();
        vector<int> vec;
        for (int i = 1; i < 4; ++i) {
            int u = read();
            vec.push_back(u);
        }
        sort(vec.begin(), vec.end());
        vec.erase(unique(vec.begin(), vec.end()), vec.end());
        vector<vector<int>> dp(4000 + 10, vector<int>(vec.size()));
        auto get_sum = [&] (int j) {
            int res = 0;
            for (int i = 0; i < vec.size(); ++i) res += dp[j][i];
            return res;
        };
        for (int i = 0; i < vec.size(); ++i) dp[vec[i]][i] = 1;
        for (int i = 1; i <= n; ++i) {
            int sum = 0;
            for (int j = 0; j < vec.size(); ++j) {
                if (i - vec[j] >= 0) {
                    int tmp = get_sum(i - vec[j]);
                    if (sum < tmp) {
                        sum = tmp;
                        for (int k = 0; k < vec.size(); ++k) dp[i][k] = dp[i - vec[j]][k] + (k == j);
                    }
                }
            }
        }
        write(get_sum(n));
    }
    return 0;
}
//3119 3515 1021 7
相关推荐
卷福同学1 小时前
【AI编程】AI+高德MCP不到10分钟搞定上海三日游
人工智能·算法·程序员
mit6.8241 小时前
[Leetcode] 预处理 | 多叉树bfs | 格雷编码 | static_cast | 矩阵对角线
算法
皮卡蛋炒饭.2 小时前
数据结构—排序
数据结构·算法·排序算法
??tobenewyorker2 小时前
力扣打卡第23天 二叉搜索树中的众数
数据结构·算法·leetcode
贝塔西塔3 小时前
一文读懂动态规划:多种经典问题和思路
算法·leetcode·动态规划
众链网络3 小时前
AI进化论08:机器学习的崛起——数据和算法的“二人转”,AI“闷声发大财”
人工智能·算法·机器学习
3 小时前
Unity开发中常用的洗牌算法
java·算法·unity·游戏引擎·游戏开发
飒飒真编程5 小时前
C++类模板继承部分知识及测试代码
开发语言·c++·算法
GeminiGlory5 小时前
算法练习6-大数乘法(高精度乘法)
算法
熬了夜的程序员5 小时前
【华为机试】HJ61 放苹果
算法·华为·面试·golang