F. Zero Remainder Sum DP好题
时间:2020-10-21
本文章向大家介绍F. Zero Remainder Sum DP好题,主要包括F. Zero Remainder Sum DP好题使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
传送门
分析
很明显是一个DP的问题
我们先提前预处理好一个数组s[i][j],i是第几行,j是对应的余数,求出f[i][j]的最大值,然后可以很容易写出状态转移方程s[i][(j + l) % k] = max(s[i][(j + l) % k],s[i - 1][j] + s[l]),但是如何去做预处理这一步呢
我一开始的思路是二进制压缩,1表示选2表示不选,后来发现70的数据范围会被t飞,所以,正解应该是每一行跑一次二维背包,一维是数字个数,二维是余数大小,然后选取不同个数相同余数之间取max即可
还有一些需要特判的小细节,注意一下即可
代码
#include <iostream>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <queue>
#include <cstring>
#define debug(x) cout<<#x<<":"<<x<<endl;
#define _CRT_SECURE_NO_WARNINGS
#pragma GCC optimize("Ofast","unroll-loops","omit-frame-pointer","inline")
#pragma GCC option("arch=native","tune=native","no-zero-upper")
#pragma GCC target("avx2")
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> PII;
const int INF = 0x3f3f3f3f;
const int N = 100;
ll f[N][N][N];
ll s[N][N];
ll a[N][N];
ll backup[N];
int n,m,k;
int main(){
scanf("%d%d%d",&n,&m,&k);
for(int i = 1;i <= n;i++)
for(int j = 1;j <= m;j++)
scanf("%lld",&a[i][j]);
memset(f,-1,sizeof f);
for(int i = 1;i <= n;i++){
f[i][0][0] = 0;
for(int j = 1;j <= m;j++)
for(int p = m / 2;p >= 1;p--)
for(int l = 0;l < k;l++){
if(f[i][p - 1][l] == -1) continue;
f[i][p][(l + a[i][j]) % k] = max(f[i][p][(l + a[i][j]) % k],f[i][p - 1][l] + a[i][j]);
}
}
for(int i = 1;i <= n;i++)
for(int j = 0;j < k;j++)
for(int l = 0;l <= m / 2;l++)
s[i][j] = max(s[i][j],f[i][l][j]);
for(int i = 2;i <= n;i++){
memcpy(backup,s[i],sizeof backup);
for(int j = 0;j < k;j++)
for(int l = 0;l < k;l++){
if((s[i - 1][j] == 0 && j != 0) || (backup[l] == 0 && l != 0)) continue;
s[i][(j + l) % k] = max(s[i][(j + l) % k],s[i - 1][j] + backup[l]);
}
}
printf("%lld\n",s[n][0]);
return 0;
}
原文地址:https://www.cnblogs.com/wuyueyu/p/13853940.html
- 碎片化 | 第四阶段-51-Hibernate注解使用-视频
- 基础JavaScript装逼指南
- 碎片化 | 第四阶段-42-校验验证码-视频
- Angularjs中UI Router超级详细的教程{{上}}
- 【LEETCODE】模拟面试-120- Triangle
- Spring Cloud Edgware新特性之四:Zuul routes端点功能增强
- Spring Cloud Edgware新特性之三:使用配置属性自定义Feign的行为
- 碎片化 | 第四阶段-43-struts2拦截器interceptor-视频
- Spring Cloud Edgware新特性之二:如何配置Zuul的Hystrix线程池
- 碎片化 | 第四阶段-44-struts2注解使用-视频
- Spring Cloud Edgware新特性之:解决Eureka中Jersey 1.x版本过旧的问题-不使用Jersey
- 如何自定义微服务的Instance ID
- 怎样做情感分析
- Python|编写自己的类
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 前端成神之路-CSS初识
- 前端成神之路-CSS基础选择器
- 前端成神之路-CSS文字文本样式
- 前端成神之路-CSS(选择器、背景、特性)
- 前端成神之路-列表和表单
- 前端成神之路-HTML
- Windows下如何查看某个端口被占用,以及如何杀死某个进程
- VSCode插件Todo Tree如何忽略某些文件夹?
- Express新建项目与配置项目热加载
- selenium控制已打开的页面
- 盘点一下lua脚本和python的区别(基础)
- python识别视频黑屏或者低清晰度
- python在linux环境下安装skimage
- python3异步爬虫 ——aiohttp模板使用
- [PHP] 抽象工厂设计模式-创建型设计模式