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

[ABC077D] Small Multiple 同余最短路

之前写过一篇介绍同余最短路的文章,其实写的蛮烂得,鸽了这道题好久,今天中午好不容易算是做出来了。

题意

给定一个 \(K\),求出来 \(V=xk\)(\(x\) 为正整数),使得这个 \(V\) 的各数位和是最小的。

这个 \(K\) 的级别是 1e5 的。

做法

我们发现直接去具体搞明白到底是哪一个数几乎是不可能的,我们不排除有一个长到你无法想象的树中间有一大堆 0 最后还是最优的,所以我们基本上否决的直接得出数的想法了。

那么我们的重心就自然而然转向维护数位和上了。

我们不难发现一个 \(V\) 的必然的性质是 \(V%K=0\),而这个 \(K\) 的范围又是如此的眉清目秀。

为什么不维护所有数呢?我这么想到。

往同余最短路考虑一下。

我们设 \(dis[i]\) 表示 \(%K=i\) 的数字中,数位和最小的数字是多少。

我们选择从小到大思考,一个数想到一个更大的数,归根结底有两种方式。

一个是加一,一个是乘十,其他的都是这个的组合。

所以我们不难列出来约束条件。

\(f_i \ge f_{(i+10)%K}\)

\(f_i +1 \ge f_{(i+1}%K\)

这样就显然起来了,按照这个约束连边就行了,应该都会同余最短路和差分约束吧,到这里就结束了。

代码↓

#include <bits/stdc++.h>
using namespace std;
const int MN=1e6+116;
struct Node{int nxt, to, w;
}node[MN];
int head[MN], tottt;
void insert(int u, int v, int w){node[++tottt].to=v;node[tottt].w=w;node[tottt].nxt=head[u];head[u]=tottt; return;
}
int K;
int dis[MN], vis[MN];
void Dijkstra(int s){memset(dis,0x3f,sizeof(dis));memset(vis,false,sizeof(vis));priority_queue <pair<int,int>> q;q.push({0,s}); dis[s]=1;while(!q.empty()){int u=q.top().second; q.pop();if(vis[u]) continue; vis[u]=true;for(int i=head[u];i;i=node[i].nxt){int v=node[i].to, w=node[i].w;if(dis[v]>dis[u]+w){dis[v]=dis[u]+w;q.push({-dis[v],v});}}}
}
int main(){ios::sync_with_stdio(0), cin.tie(0), cout.tie(0); cin>>K;for(int i=0; i<K; ++i){insert(i,(i*10)%K,0);insert(i,(i+1)%K,1);}Dijkstra(1);cout<<dis[0]<<'\n';return 0;
}
http://www.hskmm.com/?act=detail&tid=13411

相关文章:

  • 20250509_信安一把梭_黑客
  • c# 保存文件 - 先保存到临时文件,保存成功后修改文件名
  • 达芬奇标记测量线文字标题动画预设(Tracked Measuring Lines)使用指南
  • 20250427_信安一把梭_No11
  • 运营商数据分类分级:最佳实践、典型案例与智能化方案
  • AT_abc413_g [ABC413G] Big Banned Grid
  • .NET性能优化-使用RecyclableBuffer取代RecyclableMemoryStream
  • css样式:button边框贪吃蛇加载效果
  • 什么是NIC(网络接口卡)?
  • 汽车行业相关技术及其分类
  • 视频剪辑效率翻倍!CyberLink PowerDirector 从入门到专业的全能解决方案
  • 20250415_信安一把梭_encode
  • 日常练习另一部分
  • 每天一个安卓测试开发小知识之 (六)---常用的adb 命令第四期
  • SAP-ABAP中STOP,EXIT,CHECK,RETURN,CONTINUE,LEAVE,REJECT的区别
  • Linux开机启动进入紧急模式emergency mode的解决方法 - 规格严格
  • Arduino ide 软件 不建议大家使用 缺点多多
  • 视频融合平台EasyCVR国标GB28181视频诊断功能详解与实践
  • Refit Consul
  • 故障处理:Oracle 19.20未知BUG导致oraagent进程内存泄漏的案例处理
  • 麒麟服务器操作系统查询可用的内核版本以及安装和降级命令
  • esp32 stm32 ros2 三者区别
  • 20250406_信安一把梭_测试篇
  • 前端 10 个 JS 神 API,开箱即用
  • 故障处理:清除 DBA_DATAPUMP_JOBS 视图中的异常数据泵作业
  • Web自动化测试智能体详解
  • Queue 配合Thread使用
  • MyEMS 进阶应用:从单厂能耗管理到集团跨区域能源数据协同分析
  • Playwright自动化测试框架与AI智能体应用
  • 以下内容在if判定的时候会被判定为 假