思路:

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

考场上想到了没写对……

我们发现,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. How To Secure Apache with Let's Encrypt on Ubuntu (Free SSL)

    Introduction This tutorial will show you how to set up a TLS/SSL certificate from Let's Encrypt on a ...

  2. [2014年学习计划之RoR系列] 第二步 – 熟悉Ruby语言 (2/n) Blocks and Iterators (代码块和迭代器)

    [就算没有含金量,也请尊重原创, 转载自我的独立博客http://brucejia.net] Blocks and Iterators (代码块和迭代器) 代码块和迭代器是Ruby语言中比较有特点的东 ...

  3. python 网络 socket

    ---恢复内容开始--- 1.socket Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏 ...

  4. 自创open vp n windows步骤

    Easy Windows Guide¶ This page contains a no-frills guide to getting OpenVPN up and running on a Wind ...

  5. Gartner发布最新魔力象限报告,微软领跑数据库市场(编译自TechRepublic)

    知名调研机构Gartner发布了最新的<2015年数据库管理系统魔力象限调研报告>.报告显示,微软.甲骨文和AWS是数据库市场的三大领导厂商. 此份报告对知名的商用以及开源数据库厂商进行了 ...

  6. Scratch GUI

    原文地址:https://github.com/LLK/scratch-gui/wiki/Getting-Started Getting Started   Bryce Taylor edited t ...

  7. 沉淀再出发:使用python进行机器学习

    沉淀再出发:使用python进行机器学习 一.前言 使用python进行学习运算和机器学习是非常方便的,因为其中有很多的库函数可以使用,同样的python自身语言的特点也非常利于程序的编写和使用. 二 ...

  8. ZT 感触的屌丝职场记 投递人 itwriter 发布于 2013-05-27 09:21 评论(18) 有3402人阅读 原文链接 [收藏] « »   作者@幻想哥呀幻想哥   有一位屌丝男,从小抱着报效祖国的理想上了大学,毕业后干了 IT 行业,高中那时候看文汇报说,搞 IT 的在上

    屌丝职场记 投递人 itwriter 发布于 2013-05-27 09:21 评论(18) 有3402人阅读  原文链接  [收藏]  « » 作者@幻想哥呀幻想哥 有一位屌丝男,从小抱着报效祖国的 ...

  9. IOS 对JSON解析的要求

    JOSN格式的原始字符串中, 键名必须为 引号 “” 包含的字符串,值必须是数组("[]" 用中括号包起来的部分),字典("{}" 用中括号包起来的部分),数字 ...

  10. Intellij IDEA常用快捷键和一些配置——Mac版

    常用的快捷键 代码补全Ctrl + space 删除行Command + D 注释Command + / 导入包Command + shift + O 格式化代码Command + shift + F ...