思路:

这道题是个图论抽象的题目……

考场上想到了没写对……

我们发现,f函数转移的方式有两种,要么是代价10的+1,要么是代价1的乘一个质因数

那么我们就可以将这个抽象为一张图

每个i向每个i+1连一条边权为10的边

每个i向每个i*质因子[j]连一条边权为1的边

跑最短路即可

跑完最短路就是状压搜索

加上最优化剪枝和记忆化剪枝即可

代码:

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define rii register int i
#define rij register int j
#define int long long
using namespace std;
int k,dp[];
int ans,sl,ss[],sk,s[],minx,head[],cnt,jl[];
int fin=,dis[];
struct uio{
int nxt,to,val;
}x[];
void add(int from,int to,int val)
{
cnt++;
x[cnt].to=to;
x[cnt].val=val;
x[cnt].nxt=head[from];
head[from]=cnt;
}
//void dfs(int p,int q,int dj,int sd)
//{
// if(sd>100)
// {
// return;
// }
// if(dj>ans)
// {
// return;
// }
// if(q==0)
// {
// ans=min(ans,dj);
// return;
// }
// dfs(p,(q+1)%p,dj+10,sd+1);
// for(rii=1;i<=sl;i++)
// {
// dfs(p,(q*s[i])%p,dj+1,sd+1);
// }
//}
void djstl(int wz)
{
for(rii=head[wz];i!=;i=x[i].nxt)
{
if(dis[x[i].to]>dis[wz]+x[i].val)
{
dis[x[i].to]=dis[wz]+x[i].val;
djstl(x[i].to);
}
}
}
void cf(int val)
{
cnt=;
memset(head,,sizeof(head));
sl=;
for(rii=;i<=val;i++)
{
if(val%i==)
{
val/=i;
if(s[sl]!=i)
{
sl++;
s[sl]=i;
i--;
}
}
if(val==)
{
return;
}
}
}
int f(int val)
{
cnt=;
memset(x,,sizeof(x));
memset(head,,sizeof());
memset(dis,0x3f,sizeof(dis));
int p=,q=,ltt=val;
while(ltt>)
{
p+=ltt%;
ltt/=;
}
p+=;
ltt=val;
while(ltt>)
{
q*=ltt%;
ltt/=;
}
cf(val);
q+=;
q%=p;
for(rii=;i<p;i++)
{
for(rij=;j<=sl;j++)
{
add(i,i*s[j]%p,);
}
add(i,(i+)%p,);
}
dis[q]=;
djstl(q);
return dis[];
}
void cfk(int val)
{
sk=;
for(rii=;i<=val;i++)
{
if(val%i==)
{
val/=i;
if(ss[sk]!=i)
{
sk++;
ss[sk]=i;
i--;
}
}
if(val==)
{
return;
}
}
}
inline int gtv(int v)
{
int kkk=,cnt=;
while(v!=)
{
cnt++;
if(v%==)
{
kkk*=ss[cnt];
}
v/=;
}
return kkk;
}
void kfs(int zt,int dj)
{
if(dp[zt]>dj)
{
dp[zt]=dj;
}
else
{
return;
}
if(dj>=fin)
{
return;
}
if(dj<fin&&zt==(<<sk)-)
{
fin=dj;
return;
}
for(rii=;i<=(<<sk)-;i++)
{
if((zt&i)==)
{
kfs(zt|i,dj+f(gtv(i)));
}
}
}
signed main()
{
freopen("k.in","r",stdin);
freopen("k.out","w",stdout);
memset(dp,0x3f,sizeof(dp));
cin>>k;
cfk(k);
if(sk==)
{
cout<<f(k);
return ;
}
fin=f(k);
kfs(,);
cout<<fin;
}

20181031noip模拟赛T2的更多相关文章

  1. 模拟赛T2 交换 解题报告

    模拟赛T2 交换 解题报告 题目大意: 给定一个序列和若干个区间,每次从区间中选择两个数修改使字典序最小. \(n,m\) 同阶 \(10^6\) 2.1 算法 1 按照题意模拟,枚举交换位置并比较. ...

  2. 20161003 NOIP 模拟赛 T2 解题报告

    Weed duyege的电脑上面已经长草了,经过辨认上面有金坷垃的痕迹. 为了查出真相,duyege 准备修好电脑之后再进行一次金坷垃的模拟实验. 电脑上面有若干层金坷垃,每次只能在上面撒上一层高度为 ...

  3. NOIP欢乐模拟赛 T2 解题报告

    小澳的坐标系 (coordinate.cpp/c/pas) [题目描述] 小澳者表也,数学者景也,表动则景随矣. 小澳不喜欢数学,可数学却待小澳如初恋,小澳睡觉的时候也不放过. 小澳的梦境中出现了一个 ...

  4. 20180530模拟赛T2——绀碧之棺

    题目背景 qiancl 得到了一张藏宝图,上面写了一道谜题. 题目描述 定义\(F(n)\)为 n 在十进制下各个数位的平方和,求区间\([a,b]\)中有多少\(n\)满足\(k\times F(n ...

  5. 20180519模拟赛T2——pretty

    [问题描述] 小美今天对于数列很有兴趣.小美打算找出一些漂亮的序列.一个漂亮的序列的限制如下: 长度为 n ,而且数列里只包含 [1,n] 的整数. 要不是不降的序列就是不升的序列. 小美想知道有多少 ...

  6. 2019.11.11 模拟赛 T2 乘积求和

    昨天 ych 的膜你赛,这道题我 O ( n4 ) 暴力拿了 60 pts. 这道题的做法还挺妙的,我搞了将近一天呢qwq 题解 60 pts 根据题目给出的式子,四层 for 循环暴力枚举统计答案即 ...

  7. 5.12 省选模拟赛 T2 贪心 dp 搜索 差分

    LINK:T2 这题感觉很套路 但是不会写. 区间操作 显然直接使用dp不太行 直接爆搜也不太行复杂度太高. 容易想到差分 由于使得整个序列都为0 那么第一个数也要i差分前一个数 强行加一个0 然后 ...

  8. 20161023 NOIP 模拟赛 T2 解题报告

    Task 2.回文串计数 (calc.pas/calc.c/calc.cpp) [题目描述] 虽然是一名理科生,Mcx常常声称自己是一名真正的文科生.不知为何,他对于背诵总有一种莫名的热爱,这也促使他 ...

  9. 20161005 NOIP 模拟赛 T2 解题报告

    beautiful 2.1 题目描述 一个长度为 n 的序列,对于每个位置 i 的数 ai 都有一个优美值,其定义是:找到序列中最 长的一段 [l, r],满足 l ≤ i ≤ r,且 [l, r] ...

随机推荐

  1. AndroidUI多线程网络请求更新导致BUG

    昨天发现一个问题,以前做好的UI列表不用正常显示了,必须,下拉一下,才能加载内容,以前是页面自动加载第一屏幕的. 这个就不好了,只是给页面加了一个按钮啊,不应该造成这么大的问题. 按钮就是设置了一个位 ...

  2. SQL Server ->> ColumnStore Index(列存储索引)

    Columnstored index是SQL Server 2012后加入的重大特性,数据不再以heap或者B Tree的形式存储(row level)存储在每一个数据库文件的页里面,而是以列为单位存 ...

  3. [翻译] TLTagsControl

    TLTagsControl https://github.com/ali312/TLTagsControl#tltagscontrol A nice and simple tags input con ...

  4. python传递参数给shell

    #格式化字符 print "hello, %s" % ('mm') #传递参数 n="192.168.200.2" os.popen('ping %s -c 2 ...

  5. swift 数组部分排序

    数组自带排序函数,如果想实现部分排序,先对数组进行部分截取,然后对截取部分替换位排序好的子序列 var nums = [,,,,,,] var sub = nums[...] nums.replace ...

  6. August 21st 2017 Week 34th Monday

    In fact, the happiest fairy tale is no more than the simple days we have together. 其实全世界最幸福的童话,也比不上我 ...

  7. linux man指令问题

    linux man指令问题 2010-1-13 13:33 提问者: 钟离伊轩 man命令执行时,可加入数值,来限制帮助级别. 这句话对不对啊???? 我记得man page是分章节的..好像可以加数 ...

  8. windows2003 iis6配置文件和win2008/2012 iis7.5配置文件

    转载某大牛.... 日国外站的单子  :反正跑着玩 简单看下 先 在线web扫描 https://www.yascanner.com/之后发现存在注入漏洞  asp的站  穿山甲可以注入,但是发现是m ...

  9. 021.5 IO流——字符流

    ###############基本功能写 FileWriter fw = new FileWriter("xxx.txt"); fw.write("哈喽"); ...

  10. (七)Linux下的关机与重启命令

    ============================================================================================= 关机与重启命 ...