PopupWindow 设置显示坐标为负无效
2020-12-24 02:27
标签:技术 type png you mamicode enabled this window mit SDOI2013 淘金 有一个 \(X\)、\(Y\) 轴坐标范围为 \(1\sim n\) 的范围的方阵,每个点上有块黄金。一阵风来 \((x,y)\) 上的黄金到了 \((f(x),f(y))\),\(f(x)\) 为 \(x\) 各位上数字的乘积,如果黄金飘出方阵就没了。求在 \(k\) 个格子上采集黄金最多可以采集的黄金数。 数据范围:\(1\le n\le 10^{12}\),\(k\le \min(n^2,10^5)\)。 蒟蒻跟着 \(\it srf\) 大师的日报来做这题,然后发现自己的裸代码跑得比题解都快,方法也比较神奇,于是来跟巨佬们讲讲。 首先众所周知,对于 \(1\le i\le 10^{12}\),\(f(i)\) 只有 \(8282\) 种,所以可以先找出这 \(8282\) 种 \(f(i)\),蒟蒻有三种方法:set、枚举质因数和数位 dp。 为了优化可以用数位 dp(这是第一次数位 dp),正好求出 \(1\sim n\) 的所有 \(f(i)\not=0\): 然后是最重要的部分:求每种 \(f(i)\) 有多少个 \(i\)。 蒟蒻原来的做法是对每种 \(f(i)\) 来一次数位 dp,瞬间被 TLE 打脸,于是蒟蒻想出了一个不同于别的巨佬的做法: 记 \(f_{w,now}\) 表示到第 \(w\) 位,剩下 \(w\) 位乘积为 \(now\) 的方案数。 用记忆化搜索转移,dp 中会用到除法。 然后给 \(a_i\) 排个序,用堆维护找最大 \(k\) 乘积即可,考虑到相乘可能会爆 long long,蒟蒻用了除法。 时间复杂度 \(\Theta(8282*12*10)\)。 很明显蒟蒻的题解都是废话,只好放代码了。 祝大家学习愉快! PopupWindow 设置显示坐标为负无效 标签:技术 type png you mamicode enabled this window mit 原文地址:https://blog.51cto.com/xuguohongai/2518521题面
蒟蒻语
蒟蒻解
int dn,d[13],cnt=0;
ll t[N]; unordered_map
ll f[13][N];
ll dp(int w,int now,bool ava){ //w:位 now:剩下期望乘积 ava=true:可以自由选择数字
if(!~w) return t[now]==1;
if(ava&&~f[w][now]) return f[w][now];
int up=ava?9:d[w]; ll res=0;
for(int i=1;i
代码
#include