[ABC265F] Manhattan Cafe
Problem Statement
In an $N$-dimensional space, the Manhattan distance $d(x,y)$ between two points $x=(x_1, x_2, \dots, x_N)$ and $y = (y_1, y_2, \dots, y_N)$ is defined by:
\(\displaystyle d(x,y)=\sum_{i=1}^n \vert x_i - y_i \vert.\)
A point $x=(x_1, x_2, \dots, x_N)$ is said to be a lattice point if the components $x_1, x_2, \dots, x_N$ are all integers.
You are given lattice points $p=(p_1, p_2, \dots, p_N)$ and $q = (q_1, q_2, \dots, q_N)$ in an $N$-dimensional space.
How many lattice points $r$ satisfy $d(p,r) \leq D$ and $d(q,r) \leq D$?  Find the count modulo $998244353$.
Constraints
- $1 \leq N \leq 100$
- $0 \leq D \leq 1000$
- $-1000 \leq p_i, q_i \leq 1000$
- All values in input are integers.
Input
Input is given from Standard Input in the following format:
$N$ $D$
$p_1$ $p_2$ $\dots$ $p_N$
$q_1$ $q_2$ $\dots$ $q_N$
Output
Print the answer.
Sample Input 1
1 5
0
3
Sample Output 1
8
When $N=1$, we consider points in a one-dimensional space, that is, on a number line.
$8$ lattice points satisfy the conditions: $-2,-1,0,1,2,3,4,5$.
Sample Input 2
3 10
2 6 5
2 1 2
Sample Output 2
632
Sample Input 3
10 100
3 1 4 1 5 9 2 6 5 3
2 7 1 8 2 8 1 8 2 8
Sample Output 3
145428186
考虑dp,设dp_{i,j,k}表示前 $k$ 位,和串 $p$ 的距离之差为 $i$ ,和串 $q$ 的距离之差为 $j$ 的方案数。
如果把绝对值拆成四种情况来讨论,加上滚动数组,那么可以写出下面这种方法。
#include<bits/stdc++.h>
using namespace std;
const int N=105,M=1005,P=998244353;
int n,d,p[N],q[N],dp[2][M][M],ans;
int main()
{
	scanf("%d%d",&n,&d);
	for(int i=1;i<=n;i++)
		scanf("%d",p+i);
	for(int i=1;i<=n;i++)
		scanf("%d",q+i);
	dp[0][0][0]=1;
	for(int i=1;i<=n;i++)
	{
		for(int j=0;j<=d;j++)
		{
			for(int k=0;k<=d;k++)
			{
				dp[i&1][j][k]=0;
				for(int l=max(p[i]-j,q[i]-k);l<=min(p[i],q[i]);l++)
				{
					dp[i&1][j][k]+=dp[i&1^1][j-p[i]+l][k-q[i]+l];
					dp[i&1][j][k]%=P;
				}
				for(int l=max(q[i]-k,p[i]+1);l<=min(q[i]-1,p[i]+j);l++)
				{
					dp[i&1][j][k]+=dp[i&1^1][j-l+p[i]][k-q[i]+l];
					dp[i&1][j][k]%=P;
				}
				for(int l=max(q[i]+1,p[i]-j);l<=min(p[i]-1,q[i]+k);l++)
				{
					dp[i&1][j][k]+=dp[i&1^1][j-p[i]+l][k-l+q[i]];
					dp[i&1][j][k]%=P;
				}
				for(int l=max(p[i],q[i])+(p[i]==q[i]);l<=min(p[i]+j,q[i]+k);l++)
				{
					dp[i&1][j][k]+=dp[i&1^1][j-l+p[i]][k-l+q[i]];
					dp[i&1][j][k]%=P;
				}
				if(i==n)
					ans=(ans+dp[i&1][j][k])%P;
			}
		}
	}
	printf("%d",ans);
}
发现瓶颈在转移,那么就考虑能不能 \(O(1)\) 转移。
在这四种情况中,有两种情况满足后两个下标之和不变,另两种后两个下标之差不变。考虑在这一点的基础上,使用前缀和。
定义 \(f_{i,j}\) 表示在上一位中,后两个下标差为 \(i\),且第二位下标不超过 \(j\) 的所有dp 值之和,\(s_{i,j}\) 表示在上一位中,后两个下标和为 \(i\),且第二位下标不超过 \(j\) 的所有 \(dp\) 值之和。那么我们在更新 dp 值时分情况用 \(f\) 和 \(s\) 去更新就好了。
代码有些繁琐
#include<bits/stdc++.h>
using namespace std;
const int N=105,M=4005,P=998244353;
int n,d,p[N],q[N],dp[M>>2][M>>2],ans,s[M][M],f[M<<1][M],l,r;
int mo(int x)
{
	return (x%P+P)%P;
}
int main()
{
	scanf("%d%d",&n,&d);
	for(int i=1;i<=n;i++)
		scanf("%d",p+i);
	for(int i=1;i<=n;i++)
		scanf("%d",q+i);
	dp[0][0]=1;
	for(int j=0;j<=d;j++)
	{
		for(int k=0;k<=d;k++)
		{
			f[j-k+M][j+1]=f[j-k+M][j]+dp[j][k];
			f[j-k+M][j+1]%=P;
			s[j+k][j+1]=s[j+k][j]+dp[j][k];
			s[j+k][j+1]%=P;
		}
	}
	for(int i=1;i<=n;i++)
	{
		for(int j=0;j<=d;j++)
		{
			for(int k=0;k<=d;k++)
			{
				dp[j][k]=0;
				l=max(p[i]-j,q[i]-k),r=min(p[i],q[i]);
				if(l<=r)
					dp[j][k]=mo(f[j-k-p[i]+q[i]+M][j-p[i]+r+1]-f[j-k-p[i]+q[i]+M][j-p[i]+l]);
				dp[j][k]=mo(dp[j][k]);
				l=max(q[i]-k,p[i]+1),r=min(q[i]-1,p[i]+j);
				if(l<=r)
					dp[j][k]+=mo(s[j+k+p[i]-q[i]][j-l+p[i]+1]-s[j+k+p[i]-q[i]][j-r+p[i]]);
				dp[j][k]=mo(dp[j][k]);
				l=max(q[i]+1,p[i]-j),r=min(p[i]-1,q[i]+k);
				if(l<=r)
					dp[j][k]+=mo(s[j+k+q[i]-p[i]][j-p[i]+r+1]-s[j+k+q[i]-p[i]][j-p[i]+l]);
				dp[j][k]=mo(dp[j][k]);
				l=max(p[i],q[i])+(p[i]==q[i]),r=min(p[i]+j,q[i]+k);
				if(l<=r)
					dp[j][k]+=mo(f[j-k+p[i]-q[i]+M][j-l+p[i]+1]-f[j-k+p[i]-q[i]+M][j-r+p[i]]);
				dp[j][k]=mo(dp[j][k]);
				if(i==n)
					ans=(ans+dp[j][k])%P;
			}
		}
		for(int j=0;j<=d;j++)
		{
			for(int k=0;k<=d;k++)
			{
				f[j-k+M][j+1]=f[j-k+M][j]+dp[j][k];
				f[j-k+M][j+1]%=P;
				s[j+k][j+1]=s[j+k][j]+dp[j][k];
				s[j+k][j+1]%=P;
			}
		}
	}
	printf("%d",ans);
}
[ABC265F] Manhattan Cafe的更多相关文章
- robotium(及百度cafe)运行testcase之后程序挂起没有响应的原因调查及解决
		一.问题背景 刚开始用的是百度cafe搭建的框架,已经用了一些版本,最后的test版本在7.4的apk上能跑,但是在最新发布的7.5的版本上跑不了,直接提示nullPointer错误,通过打日志的方式 ... 
- R语言画全基因组关联分析中的曼哈顿图(manhattan plot)
		1.在linux中安装好R 2.准备好画曼哈顿图的R脚本即manhattan.r,manhattan.r内容如下: #!/usr/bin/Rscript #example : Rscript plot ... 
- Manhattan distance(for lab)
		Input four integer x1, y1, x2, y2, which is mean that the coordinates of two points A(x1, y1), B(x2, ... 
- bzoj 3170 manhattan距离
		首先将坐标系顺时针旋转45度,得到一个新的坐标系,这个坐标系 对应的坐标的manhattan距离就是原图中的距离,然后快排,利用前缀和 数组O(N)求所有的答案,然后找最小值就行了,总时间O(Nlog ... 
- GWAS: 曼哈顿图,QQ plot 图,膨胀系数( manhattan、Genomic Inflation Factor)
		画曼哈顿图和QQ plot 首推R包“qqman”,简约方便.下面具体介绍以下. 一.画曼哈顿图 install.packages("qqman") library(qqman) ... 
- 基于Manhattan最小生成树的莫队算法
		点u,v的Manhattan距离:distance(u,v)= |x2-x1|+|y2-y1| Manhattan最小生成树:边权值为两个点Manhattan距离的最小生成树. 普通算法:prim复杂 ... 
- manhattan plots in qqplot2
		###manhattan plots in qqplot2library(ggplot2)setwd("~/ncbi/zm/XPCLR/")read.table("LW. ... 
- CAFE: a computational tool for the study of gene family evolution
		1.摘要 摘要:我们提出了CAFE(计算分析基因家族进化),这是一个统计分析基因家族进化规模的工具.它使用随机的出生和死亡过程来模拟一个系统发育过程中基因家族大小的进化.对于一个特定的系统发育树,并给 ... 
- 百度Cafe原理--Android自动化测试学习历程
		主要讲解内容及笔记: 一.Cafe原理 Cafe是一款自动化测试框架,解决问题:跨进程测试.快速深度测试 官网:http://baiduqa.github.io/Cafe/ Cafe provides ... 
- codechef FEB19 Manhattan Rectangle
		Manhattan Rectangle 链接 题意: 交互题,询问小于7次,确定一个矩形的位置,每次询问一个点到矩形的曼哈顿距离. 分析: 询问三个顶点,然后解一下方程,求出一个边界,就好办了. 用s ... 
随机推荐
- 设置服务账号Service Accounts(sa)的token不挂载到pod
			目录 一.系统环境 二.前言 三.Service Accounts(sa)简介 四.在pod里设置sa的token不挂载到pod 五.在sa里设置sa对应的token不挂载到pod上 六.总结 一.系 ... 
- 4.1 应用层Hook挂钩原理分析
			InlineHook 是一种计算机安全编程技术,其原理是在计算机程序执行期间进行拦截.修改.增强现有函数功能.它使用钩子函数(也可以称为回调函数)来截获程序执行的各种事件,并在事件发生前或后进行自定义 ... 
- 使用MySQL存储过程提高数据库效率和可维护性
			MySQL 存储过程是一种强大的数据库功能,它允许你在数据库中存储和执行一组SQL语句,类似于编程中的函数.存储过程可以大幅提高数据库的性能.安全性和可维护性.本文将详细介绍MySQL存储过程的使用. ... 
- Solution -「洛谷 P5659」「CSP-S 2019」树上的数
			Description Link. 联赛原题应该都读过吧-- Solution Part 0 大致思路 主要的思路就是逐个打破,研究特殊的数据得到普通的结论. Part 1 暴力的部分分 暴力的部分分 ... 
- 200PLC转以太网与1200PLC实现PUT GET通信
			200PLC转以太网与1200PLC实现PUT GET通信 本案例介绍西门子PLC200PLC 224或226,Port0或者是Port1串口通过兴达易控PPI-ETH-XD1.0plc以太网模块,2 ... 
- 解密网络通信的关键技术(下):DNS、ARP、DHCP和NAT,你了解多少?
			引言 在上一章中,我们详细介绍了域名系统(DNS)和地址解析协议(ARP)的工作原理,从而对域名解析和介质访问控制(MAC)地址寻址有了更深入的了解.在今天的章节中,我们将继续探讨动态主机配置协议(D ... 
- RabbitMQ——RabbitMQ面试题
			文章目录 为什么使用MQ?MQ的优点 消息队列有什么优缺点?RabbitMQ有什么优缺点? 你们公司生产环境用的是什么消息中间件? Kafka.ActiveMQ.RabbitMQ.RocketMQ 有 ... 
- 通过资源名称得到资源id
			demo地址 主要应用类 package com.example.activitylibrary; import android.app.Activity; import android.os.Bun ... 
- ChatGPT API FAQ
			ChatGPT API FAQ General questions about the ChatGPT API Written by Johanna C.. Updated over a week a ... 
- 单元测验4:人格知识大比武2mooc
			单元测验4:人格知识大比武2 返回 本次得分为:10.00/10.00, 本次测试的提交时间为:2020-09-06, 如果你认为本次测试成绩不理想,你可以选择 再做一次 . 1 单选(2分) 关于M ... 
