当前位置: 首页 > news >正文

洛谷P2474 [SCOI2008] 天平 题解

思路学习的这一篇

step1

首先我们设 \(mn_{i,j}\)为砝码 \(i\) -砝码 \(j\) 的最小值(下文以\(a_i\)\(a_j\)代替)。
\(mx_{i,j}\)\(a_i-a_j\)的最大值。

当设\(a_i\)\(a_j\)的关系为\(g_{i,j}\)

\(g_{i,j}\)为=\(+\)时,

a[i]  a[j]    a[i]-a[j]3     1         22     1         13     2         1

明显,\(mx_{i,j}=2\),\(mn_{i,j}=1\)

\(g_{i,j}\)\(-\)时,

a[i]  a[j]    a[i]-a[j]1     3        -21     2        -12     3        -1

\(mx_{i,j}=-1\),\(mn_{i,j}=-2\)
\(g_{i,j}\)\(=\)
\(\because a_i=a_j\)
\(\therefore mn_{i,j}=mn_{i,j}=0\)

最后当\(g_{i,j}\)\(?\)
\(mx_{i,j}=2\),\(mn_{i,j}=-2\)(相当于\(+\)\(-\))的结合
综上

\[\begin{cases} mx_{i,j}=2,mn_{i,j}=1 & g_{i,j}为+\\ mx_{i,j}=-1,mn_{i,j}=-2 & g_{i,j}为-\\ mx_{i,j}=0,mn_{i,j}=0 & g_{i,j}为=\\ mx_{i,j}=2,mn_{i,j}=-2 & g_{i,j}为?\\ \end{cases} \]

step2

我们知道了\(mx\)\(mn\)的值,接下来题面说要唯一情况,所以我们要差分约束
\(mn_{i,j}\)记录的是\(a_i-a_j的最小差值\)。那我们可以找一个\(k\)

\[mn_{i,j}=a_i-a_j\\ \hspace{7em} =a_i-a_k+a_k-a_j\\ \hspace{5.7em}=mn_{i,k}+mn_{k,j} \]

因为题目要求唯一答案,\(mn_{i,j}\)要尽可能大
所以

\[mn_{i,j}=\max\limits_{k=1}^{n} mn_{i,k}+mn_{k,j} \]

同理

\[mx_{i,j}=\min\limits_{k=1}^{n} mx_{i,k}+mx_{k,j} \]

step3

\(A+B>a_i+a_j\)

\[A+B>a_i+a_j\\ \hspace{3em}A-a_i+B-a_j>0\rightarrow mn_{A,i}+mn_{B,j}>0\\ \hspace{3em}A-a_j+B-a_i>0\rightarrow mn_{A,j}+mn_{B,i}>0\\ \]

\(A+B<a_i+a_j\)类似

\[A+B<a_i+a_j\\ \hspace{3em}A-a_i+B-a_j<0\rightarrow mx_{A,i}+mx_{B,j}<0\\ \hspace{3em}A-a_j+B-a_i<0\rightarrow mx_{A,j}+mx_{B,i}<0\\ \]

\(A+B=a_i+a_j\)有点不同。因为既要满足\(mx\)相等,又要满足\(mn\)相等。

\[\hspace{-15em}\textcircled{1}\\ A+B=a_i+a_j\\ \hspace{8.2em}{A-a_i+B-a_j=0}\rightarrow{mx_{A,i}=mn_{A,i},mx_{B,j}=mn_{B,j}}\\ \hspace{-4.3em}{{A,i}+{B,j}=0} \]

\[\hspace{-15em}\textcircled{2}\\ A+B=a_i+a_j\\ \hspace{8.2em}{A-a_j+B-a_i=0}\rightarrow{mx_{A,j}=mn_{A,j},mx_{B,i}=mn_{B,i}}\\ \hspace{-4.3em}{{A,j}+{B,i}=0} \]

\(\because mx_{i,j}=mn_{i,j}\)
\(\therefore\)\(mx\) \(mn\)都行

step4

#include<bits/stdc++.h>
using namespace std;
const int N=55;
char g[N][N];
int mx[N][N],mn[N][N];
int n,A,B;
void csh()
{for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(g[i][j]=='+')mx[i][j]=2,mn[i][j]=1;if(g[i][j]=='-')mx[i][j]=-1,mn[i][j]=-2;if(g[i][j]=='=')mx[i][j]=mn[i][j]=0;if(g[i][j]=='?')mx[i][j]=2,mn[i][j]=-2;if(i==j)mx[i][j]=mn[i][j]=0;}}
}
int main()
{cin>>n>>A>>B;for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){cin>>g[i][j];}}csh();for(int k=1;k<=n;k++){	for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){mn[i][j]=max(mn[i][j],mn[i][k]+mn[k][j]);mx[i][j]=min(mx[i][j],mx[i][k]+mx[k][j]);}}}int c1=0,c2=0,c3=0;for(int i=1;i<=n;i++){for(int j=i+1;j<=n;j++){if(i==A||i==B||j==A||j==B)continue;if(mn[A][i]+mn[B][j]>0||mn[A][j]+mn[B][i]>0)c1++;if(mx[A][i]+mx[B][j]<0||mx[A][j]+mx[B][i]<0)c3++;if(mn[A][i]==mx[A][i]&&mn[B][j]==mx[B][j]&&mn[A][i]+mn[B][j]==0)c2++;else if(mn[A][j]==mx[A][j]&&mn[B][i]==mx[B][i]&&mn[A][j]+mn[B][i]==0)c2++;}}cout<<c1<<' '<<c2<<' '<<c3;return 0;
}
http://www.jsqmd.com/news/17489/

相关文章:

  • Telnet发送邮件
  • 一天一款实用的AI工具,第8期,AI转素描风格
  • 2025年预应力张拉设备厂家推荐排行榜,千斤顶,预应力千斤顶,预应力张拉千斤顶,预应力张拉机,锚具,预应力锚具,桥梁施工锚具公司精选
  • 完整教程:【C++】string类
  • 【ACM独立出版|EI稳定】第二届云计算与大数据国际学术会议(ICCBD 2025)
  • 机器学习周报十五 - 教程
  • 完整教程:【LeetCode 每日一题】2221. 数组的三角和
  • 软件设计中的需求分析——白日梦
  • 包装工位连接断开,终检产品无法进入包装
  • 2025年苹果仓厂家权威推荐榜单:苹果仓民宿,移动房苹果仓,出口苹果仓,外贸出口苹果仓,集装箱苹果仓,景区苹果仓,苹果仓房屋,网红苹果仓,可移动式苹果仓公司推荐
  • 实时物化视图的新路径:从传统 Join 到跨源实时查询
  • 2025年拉链厂家权威推荐榜:TAB拉链,大棕拉链,金属/树脂拉链,服装/尼龙拉链,防水/隐形拉链,男装/女装拉链源头精选
  • 多轮对话中,如何判断前后两次提问是否存在依赖关系
  • 基于SpringBoot的课程信息管理系统设计与实现 - 实践
  • 2025年全自动智能点胶机厂家推荐排行榜:饰品/纽扣/拉链头/商标/钥匙扣/五金/徽章视觉定位UV胶点胶设备精选
  • 2025年环氧板厂家推荐排行榜,环氧板加工,FR-4玻纤板,云母板源头厂家专业制造与品质保障
  • 2025 钢制拖链源头厂家最新推荐排行榜:权威甄选优质品牌,破解选型难题助力企业精准采购
  • 机器学习可扩展性:从1到百万用户的架构演进
  • SOSDP
  • 2025年保洁公司推荐排行榜,驻场保洁/钟点保洁/开荒保洁/外包保洁/商场保洁/办公楼保洁/工厂保洁/医院保洁/企业保洁服务优选指南
  • 图像增强任务
  • 20232320 2025-2026-1 《网络与系统攻防技术》实验二实验报告
  • spi+dma接收,dma失能后不能使能
  • 2025年锯床厂家权威推荐榜:数控锯床、立式锯床专业选购指南与实力厂家深度解析
  • 【征文计划】基于Rokid CXR-M SDK 打造AI 实时会议助手:从连接到自定义界面的完整实践 - 教程
  • 在AI技术快速实现创意的时代,挖掘新需求成为核心竞争力——某知名内容管理系统能力框架需求探索
  • 2025年方钢/扁钢/圆钢/光轴/六角钢/异型钢/冷拉冷拔钢/热轧钢厂家推荐排行榜,Q355B/Q345B/16Mn/45#/40Cr/A3/Q235B材质优质供应商精选
  • 水韵文脉与科创烟火:无锡城市旅游宣传片的专业化叙事构建 - 详解
  • 单细胞转录组:差异基因分析和富集分析 - 教程
  • DBA必备脚本:Oracle获取绑定变量的字面SQL文本版版本替代