[USACO24OPEN] Smaller Averages G (单调性优化dp)

来源

题目

Bessie 有两个长度为 N的数组(1≤N≤500)。第一个数组的第 i 个元素为 ai​(1≤ai​≤10^6),第二个数组的第 i个元素为bi​(1≤bi​≤10^6)。

Bessie 希望将两个数组均划分为若干非空子数组,使得以下条件成立。

  1. 每个元素恰属于 1个子数组。
  2. 两个数组划分为相同数量的子数组。令第一个和第二个数组被划分为的子数组数量为 k(即,第一个数组被划分为恰好 k个子数组,第二个数组被划分为恰好 k 个子数组)。
  3. 对于所有1≤i≤k,第一个数组左数第 i 个子数组的平均值小于或等于第二个数组左数第 i个子数组的平均值。

计算她有多少种方式在满足限制的情况下将两个数组划分为非空子数组,对 10^9+7取模。两种划分方式被认为是不同的,如果子数组的数量不同或是某个元素属于不同的子数组。

输入格式

输入的第一行包含 NN。

第二行包含 a_1,a_2,\ldots,a_Na1​,a2​,…,aN​。

第三行包含 b_1,b_2,\ldots,b_Nb1​,b2​,…,bN​。

输出格式

输出在满足限制的情况下将两个数组划分为非空子数组的方法数模 10^9+7109+7 的余数。

思路

        首先不管复杂度,先考虑n^{4}的dp

        设dp_{i, j}为a数组的第i位和 b数组 的第 j 位相匹配的时方案数,那么dp_{i,j}应该为满足条件的数字对dp_{l, k}的和,条件就是a数组l到i的平均值,小于或等于b数组k到j的平均值,算平均值的时候要把除法转化为乘法,避免精度的缺失,对于这个dp只要暴力枚举i,j,l,k就行。

        对于题目所要求的n^{3}的复杂度,可以考虑只枚举三个变量,考虑用单调性优化掉其中的一维,但是对于一个数组的每一段的平均值必然不满足单调性,可以想到固定区间的右端点,把以此为右端点的区间全部根据区间的平均值进行排序。将两个数组的每一个i,j都做这样的预处理之后。

        我们之前是枚举l和k,现在只需要枚举k,对于固定的k,l一个是随着k 的增加而增加或者不变的,这样就优化了枚举l 的复杂度。

#include<bits/stdc++.h>using namespace std;
#define int long longconst int N = 666;
const int mod = 1e9 + 7;int n;
int l;
int a[N], b[N], suma[N], sumb[N];
int dp[N][N], sum[N][N];
struct node {int l, r, w;
} aa[N][N], bb[N][N];bool cmp(node xx, node yy) {return xx.w * (yy.r - yy.l + 1) <= yy.w * (xx.r - xx.l + 1);
}void solve() {cin >> n;for (int i = 1; i <= n; i++) {cin >> a[i];suma[i] = suma[i - 1] + a[i];}for (int i = 1; i <= n; i++) {cin >> b[i];sumb[i] = sumb[i - 1] + b[i];}for (int i = 1; i <= n; i++) {for (int j = i; j <= n; j++) {aa[j][i].l = i;aa[j][i].r = j;aa[j][i].w = suma[j] - suma[i - 1];bb[j][i].l = i;bb[j][i].r = j;bb[j][i].w = sumb[j] - sumb[i - 1];}}for (int i = 1; i <= n; i++) {sort(aa[i] + 1, aa[i] + 1 + i, cmp);sort(bb[i] + 1, bb[i] + 1 + i, cmp);}dp[0][0] = 1;for (int i = 1; i <= n; i++) {memset(sum, 0, sizeof(sum));for (int k = 1; k <= i; k++) {for (int j = 1; j <= n; j++) {sum[k][j] = (sum[k - 1][j] + dp[aa[i][k].l - 1][j - 1]) % mod;}}for (int j = 1; j <= n; j++) {l = 1;for (int k = 1; k <= j; k++) {while (l <= i) {if (cmp(aa[i][l], bb[j][k])) {l++;} else break;}if (l!=1)dp[i][j] = (dp[i][j] + sum[l - 1][bb[j][k].l]) % mod;}}}cout << dp[n][n];}signed main() {ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);solve();return 0;
}

        

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/46083.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习(五) -- 监督学习(6) --逻辑回归

系列文章目录及链接 上篇&#xff1a;机器学习&#xff08;五&#xff09; -- 监督学习&#xff08;5&#xff09; -- 线性回归2 下篇&#xff1a;机器学习&#xff08;五&#xff09; -- 监督学习&#xff08;7&#xff09; --SVM1 前言 tips&#xff1a;标题前有“***”的内…

uniapp 支付宝小程序 芝麻免押 免押金

orderStr参数如下&#xff1a; my.tradePay({orderStr:res, // 完整的支付参数拼接成的字符串&#xff0c;从 alipay.fund.auth.order.app.freeze 接口获取success: (res) > {console.log(免押成功);console.log(JSON.stringify(res),不是JOSN);console.log(JSON.stringify…

使用机器学习 最近邻算法(Nearest Neighbors)进行点云分析 (scikit-learn Open3D numpy)

使用 NearestNeighbors 进行点云分析 在数据分析和机器学习领域&#xff0c;最近邻算法&#xff08;Nearest Neighbors&#xff09;是一种常用的非参数方法。它广泛应用于分类、回归和聚类分析等任务。下面将介绍如何使用 scikit-learn 库中的 NearestNeighbors 类来进行点云数…

[GICv3] 3. 物理中断处理(Physical Interrupt Handling)

中断生命周期 ​​ 外设通过中断信号线生成中断&#xff0c;或者软件生成中断&#xff08;SGI&#xff09;。Distributor 和 ReDistributor 配合按照中断分组和中断优先级仲裁后将最高优先级的中断分发到 CPU interface。cpu interface 向中断发送到 PEPE 读取 IAR 寄存器&am…

使用Java连接星火认知大模型:一个实际案例解析

引言&#xff1a; 随着人工智能技术的快速发展&#xff0c;认知大模型如星火在自然语言处理、语音识别等领域发挥着越来越重要的作用。本文将通过一个实际的Java代码示例&#xff0c;详细讲解如何使用Java连接星火认知大模型&#xff0c;并处理其响应。 1.导入依赖&#xff1…

【防火墙】防火墙安全策略用户认证综合实验

实验拓扑及要求 拓扑搭建及IP配置 防火墙&#xff08;总公司&#xff09;和交换机&#xff08;汇聚生产区和办公区&#xff09;的接口配置 生产区在vlan2&#xff0c;办公区在vlan3&#xff0c;防火墙在G1/0/3接口上创建子接口G1/0/3.1和G1/0/3.2对两个区域分别进行管理 交换…

全国297个地级市 2006年-2021年 绿地面积、建成区绿化覆盖率(数据整理)

城市绿化覆盖数据&#xff1a;评估生态环境与生活质量的指标 城市绿化是衡量一个城市生态环境质量和居民生活质量的重要指标。绿地面积和建成区绿化覆盖率是两个关键的数据点&#xff0c;它们提供了对城市绿化状况的直接观察。 绿地面积与建成区绿化覆盖率的定义&#xff1a;…

【postgresql】锁

PostgreSQL 提供了多种锁模式来控制对表和行的并发访问&#xff0c;以确保数据的一致性和完整性。这些锁模式包括表级锁和行级锁&#xff0c;它们可以由应用程序显式控制&#xff0c;也可以在执行大多数 PostgreSQL 命令时自动获取。 锁类型 PostgreSQL类型的锁包括&#xff…

数据结构(Java):树二叉树

目录 1、树型结构 1.1 树的概念 1.2 如何判断树与非树 1.3 树的相关概念 1.4 树的表示形式 1.4.1 孩子兄弟表示法 2、二叉树 2.1 二叉树的概念 2.2 特殊的二叉树 2.3 二叉树的性质 2.4 二叉树的存储 2.5 二叉树的遍历 1、树型结构 1.1 树的概念 树型结构是一种非线…

prompt第二讲-langchain实现中英翻译助手

文章目录 prompt模板 (prompt template)langchain 中的prompt模板 (prompt template)langchain实现中英翻译助手 prompt模板 (prompt template) 开篇我介绍了在llm中&#xff0c;通常输入的那个字符串会被我们称之为prompt&#xff0c;下面就是一个中英文翻译助手的prompt例子…

【Three.js基础学习】16.Physice

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 前言 课程回顾 物理库 3D Ammo.js Cannon.js Oimo.js 2D Matter.js P2.js Planck.js Box2D.js 补充:一些看似3D的效果实际使用2D库来实现的 物理 和 three.js的结合 概念补充…

Java核心篇之JVM探秘:对象创建与内存分配机制

系列文章目录 第一章 Java核心篇之JVM探秘&#xff1a;内存模型与管理初探 第二章 Java核心篇之JVM探秘&#xff1a;对象创建与内存分配机制 第三章 Java核心篇之JVM探秘&#xff1a;垃圾回收算法与垃圾收集器 第四章 Java核心篇之JVM调优实战&#xff1a;Arthas工具使用及…

《Windows API每日一练》9.25 系统菜单

/*------------------------------------------------------------------------ 060 WIN32 API 每日一练 第60个例子POORMENU.C&#xff1a;使用系统菜单 GetSystemMenu函数 AppendMenu函数 (c) www.bcdaren.com 编程达人 -------------------------------------------…

亿康源用科技引领发展,开启大健康产业新篇章

&#xff08;本台记者报&#xff09;近日&#xff0c;杭州有一家公司凭借深厚的科技研发实力与卓越的创新能力在大健康领域屡受好评&#xff0c;其研发的新品一经推出便成为行业热议。为了探寻该公司的经营秘诀&#xff0c;我们找到了这家公司——亿康源&#xff0c;并有幸与亿…

防火墙组网与安全策略实验

实验要求&#xff1a; 实现&#xff1a; 防火墙接口配置&#xff1a; 所有接口均配置为三层接口 由于G1/0/3口下为vlan环境&#xff0c;所以防火墙需要配置子接口 &#xff1a; 交换机划分vlan分开生产区和办公区、配置trunk干道 &#xff1a; 安全策略&#xff1a; 生产区访…

深度学习概览

引言 深度学习的定义与背景 深度学习是机器学习的一个子领域&#xff0c;涉及使用多层神经网络分析和学习复杂的数据模式。深度学习的基础可以追溯到20世纪80年代&#xff0c;但真正的发展和广泛应用是在21世纪初。计算能力的提升和大数据的可用性使得深度学习在许多领域取得…

[C++] 由浅入深理解面向对象思想的组成模块

文章目录 (一) 类的默认成员函数(二) 构造函数构造函数的特征构造函数示例无参构造带参构造 冲突:全缺省参数的构造函数与无参构造函数 &#xff08;三&#xff09;析构函数特性析构函数的析构过程解析 &#xff08;四&#xff09;拷贝构造函数什么是拷贝构造&#xff1f;特性为…

初始c语言(2)运算符与表达式

一 c语言提供的运算符类型 以上会后续介绍 二 现阶段我们掌握如下的基本操作符 注意&#xff01;计算机的除法只会保留整数部分&#xff08;若被除数未负则不同的软件取整的结果不唯一&#xff09; 三 自加&#xff08;&#xff09;自减&#xff08;--&#xff09;符号 若为…

GESP CCF C++ 四级认证真题 2024年6月

第 1 题 下列代码中&#xff0c;输出结果是&#xff08; &#xff09; A. 12 24 24 12 B. 24 12 12 24 C. 12 12 24 24 D. 24 24 12 12 第 2 题 下面函数不能正常执行的是&#xff08;&#xff09; A. B. C. D. 第 3 题 下面程序…

AI Native时代:重塑人机交互与创作流程

随着2024年上海世界人工智能大会的圆满落幕&#xff0c;业界领袖们纷纷就AI应用的新机遇展开深入讨论。结合a16z播客中的观点&#xff0c;本文将探讨AI原生&#xff08;AI Native&#xff09;应用的几个关键特征&#xff0c;这些特征正在重新定义我们的工作方式和创作过程。 一…