那一天我们许下约定

内部题,题干不粘了。

$30分算法$


首先看数据范围,可以写出来一个普通dp

#include<bits/stdc++.h>
#define ll int
#define A 2100
#define mod 998244353
using namespace std;
ll f[1501][A+A+A],n,d,m;
int main()
{
scanf("%d%d%d",&n,&d,&m);
while(n!=0&&d!=0&&m!=0){
memset(f,0,sizeof(f));
f[0][0]=1;
for(ll i=1;i<=d;i++)
f[0][i]=1;
for(ll i=1;i<=n;i++)
for(ll k=1;k<=d;k++)
{
for(ll j=min(m-1,i);j>=0;j--)
if(i-j>=0) f[i][k]=(f[i][k]+f[i-j][k-1])%mod;
}
printf("%d\n",f[n][d]);
scanf("%d%d%d",&n,&d,&m);
}
}

d最大为$1e^12$所以你这个dp会完美T掉或者M掉

$100分算法$


观察,发现n的范围非常小,m的范围也特别小。

所以我们利用这条性质,先片面的忽视掉这一天不给她饼干的情况,我们设定$f$定义为每天都给她饼干的情况。

设$f[i][j]$中i表示为前$i$天目前给了$j$个饼干的情况

然后可以推出来方程式

可以给她1~m-1个饼干

$f[i][j]=\sum_\limits {k=(j-M-1)}^{k<=j-1} f[i-1][k]$

然后直接转移,复杂度仍然难以接受,观察dp式子发现它是由一个字段转移过来的,我们要用前缀和维护优化一下。

仍然AC不了?

可能你会乘爆long long

注意多取模

#include<bits/stdc++.h>
#define ll long long
#define A 2010
#define mod 998244353
using namespace std;
ll f[A][A],n,m,q,d;
ll sum[A];
ll meng(ll x,ll k)
{
ll ans=1;
for(;k;k>>=1,x=x*x%mod)
if(k&1)
ans=x*ans%mod;
return ans%mod;
}
int main(){ while(1){
scanf("%lld%lld%lld",&n,&d,&m);
ll ans=0;
if(n==0&&d==0&&m==0){
return 0;
}
memset(f[1],0,sizeof(f[1]));
f[0][0]=1;
for(ll i=1;i<=min(n,m-1);i++)
f[1][i]=1;
for(ll i=2;i<=n;i++){
for(ll j=0;j<=n;j++)
sum[j]=(sum[j-1]%mod+f[i-1][j]%mod)%mod;
for(ll j=1;j<=n;j++)
f[i][j]=(sum[j-1]%mod-sum[max(j-m,0ll)]%mod+mod)%mod;
}
ll sd=d%mod;
for(ll i=1;i<=min(n,d);i++)
{
if(i==1)
ans=(ans+sd*f[i][n]%mod)%mod,ans%=mod;
else{
sd=(sd%mod*meng(i,mod-2)%mod*((d-i+1)%mod))%mod;
ans%=mod;
ans=(ans+f[i][n]%mod*sd%mod)%mod;
}
// if(sd!=0)printf("sd=%lld ans=%lld f*s=%lld\n",sd,ans,f[i][n]*sd%mod);
}
cout<<(ans+mod)%mod<<endl;
}
}

那一天她离我而去

听说暴力可以AC所以我打的A*???

看不懂题解,如果给一个菊花图题解不就爆炸了吗?$2^{10000}$我觉得会炸

所以这个题瞎搞就行了???

然后我就瞎搞了个A*

跑的还特别快。大约600毫。

思路大约就是把每个直接与1相连的点拿出来,然后对于每个点跑A*,因为已经提前处理出来各种dis所以比较快。

然后没了

#include<bits/stdc++.h>
using namespace std;
#define ll int
#define A 100010
#define in inline
ll n,m;
bool flag[A],ok=0;
ll head[A],nxt[A],ver[A],tot1=0,t;
ll head2[A],nxt2[A],ver2[A],cnt=0,tot2=0;
ll value[A],value2[A],e,d[A],len=0;
struct qnode{
ll v,w,sz,id;
friend bool operator < (qnode x,qnode y)
{
return x.w+d[x.v]>y.w+d[y.v];
}
};
void re()
{
tot1=1,tot2=1;
memset(flag,0,sizeof(flag));
memset(head,0,sizeof(head));memset(head2,0,sizeof(head2));
memset(ver,0,sizeof(ver));memset(ver2,0,sizeof(ver2));
memset(nxt,0,sizeof(nxt));memset(nxt2,0,sizeof(nxt2));
memset(value,0,sizeof(value));memset(value2,0,sizeof(value2));
}
in void add1(ll u,ll v,ll w)
{
ver[++tot1]=v;
nxt[tot1]=head[u];
value[tot1]=w;
head[u]=tot1;
}
in void add2(ll x,ll y,ll w)
{
ver2[++tot2]=y;
nxt2[tot2]=head2[x];
value2[tot2]=w;
head2[x]=tot2;
}
in void spfa(ll root)
{
memset(flag,0,sizeof(flag));
memset(d,0x3f,sizeof(d));
queue <ll>q;
q.push(root);
flag[root]=1;
d[root]=0;
while(!q.empty())
{
ll x=q.front();
q.pop();
flag[x]=0;
for(ll i=head[x];i;i=nxt[i])
{
ll y=ver[i],w=value[i];
if(d[y]>d[x]+w)
{
d[y]=d[x]+w;
if(!flag[y])
{
flag[y]=1;
q.push(y);
}
}
}
}
return ;
}
in ll read()
{
ll x=0,f=1;char c=getchar();
while(!isdigit(c))
{
if(c=='-') f=-1;
c=getchar();
}
while(isdigit(c))
{
x=(x<<1)+(x<<3)+c-'0';
c=getchar();
}
return x*f;
}
in ll astar()
{
// 从每个直接相连的点开始跑A*
ll ans=0x7ffffff;
for(ll i=head[1];i;i=nxt[i])
{
ll y=ver[i];
priority_queue<qnode> h;
memset(flag,0,sizeof(flag));
qnode s;
s.v=y,s.w=value[i],s.id=0;
h.push(s);
bool ok=0;
while(!h.empty())
{
qnode no=h.top();
// printf("当前 %d sumvalue=%d\n",no.v,no.w);
if(no.v==1){
ans=min(no.w,ans);
break;
}
h.pop();
flag[no.v]=1;
for(ll i=head2[no.v];i;i=nxt2[i]){
ll tu=ver2[i];
// printf("tu=%d\n",tu);
if(tu==1&&!ok){
ok=1;
// printf("tu=%d \n",tu);
continue;
}
if(flag[tu])
{/*printf("掠过\n");*/continue;}
// printf("没有掠过\n");
qnode t;
t.v=tu;t.w=value[i]+no.w;t.sz=no.sz+1;
h.push(t);
// printf("推入 %d->%d z=%d\n",no.v,tu,value2[i]+no.w);
}
}
}
return ans;
} int main()
{
scanf("%d",&t);
while(t--)
{
re();
ll xx,yy;ll zz;
n=read(),m=read();
for(ll i=1;i<=m;i++)
{
xx=read(),yy=read();zz=read();
add1(yy,xx,zz);
add1(xx,yy,zz);
add2(xx,yy,zz);
add2(yy,xx,zz);
}
spfa(1);
/* for(ll i=2;i<=tot1;i++){
printf("%d\n",ver[i]);
}
for(ll i=1;i<=n;i++){
printf("%d\n",d[i]);
}
*/ ok=1;
ll ans=astar();
if(ans>=1000000) cout<<-1<<endl;
else
printf("%d\n",ans);
}
}

NOIP模拟测试6「那一天我们许下约定(背包dp)·那一天她离我而去」的更多相关文章

  1. NOIP模拟测试19「count·dinner·chess」

    反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...

  2. NOIP模拟测试30「return·one·magic」

    magic 题解 首先原式指数肯定会爆$long$ $long$ 首先根据欧拉定理我们可以将原式换成$N^{\sum\limits_{i=1}^{i<=N} [gcd(i,N)==1] C_{G ...

  3. NOIP模拟测试21「折纸&#183;不等式」

    折纸 题解 考试时无限接近正解,然而最终也只是接近而已了 考虑模拟会爆炸,拿手折纸条试一试,很简单 考你动手能力 代码 #include<bits/stdc++.h> using name ...

  4. NOIP模拟测试18「引子·可爱宝贝精灵·相互再归的鹅妈妈」

    待补 引子 题解 大模拟,注意细节 代码1 #include<bits/stdc++.h> using namespace std; int n,m;char a[1005][1005]; ...

  5. NOIP模拟测试10「大佬·辣鸡·模板」

    大佬 显然假期望 我奇思妙想出了一个式子$f[i]=f[i-1]+\sum\limits_{j=1}^{j<=m} C_{k \times j}^{k}\times w[j]$ 然后一想不对得容 ...

  6. 20190803 NOIP模拟测试12「斐波那契(fibonacci)· 数颜色 · 分组 」

    164分 rank11/64 这次考的不算太差,但是并没有多大的可能性反超(只比一小部分人高十几分而已),时间分配还是不均,T2两个半小时,T1半个小时,T3-额十几分钟吧 然额付出总是与回报成反比的 ...

  7. NOIP模拟测试8「寿司」

    考试时打的类似$n^2$暴力,然后炸了只有10分 后来验证我的算法伪了. 题解 显然你有一种解法,假设你要在一个B点断开将R分别移向最左 最右,这样只用分别计算B点右面蓝色数量左面蓝色数量就得到了一个 ...

  8. NOIP模拟测试38「金·斯诺·赤」

    金 辗转相减见祖宗 高精 #include<bits/stdc++.h> using namespace std; #define A 2000 #define P 1 #define N ...

  9. NOIP模拟测试28「阴阳·虎·山洞」

    写这几个题解我觉得我就像在按照官方题解抄一样 阴阳 题解 将题目中给的阴阳看作黑色和白色 首先我们观察到最后生成图中某种颜色必须是竖着单调递增或竖着单调递减 类似这样 否则不满足这个条件 但合法染色方 ...

随机推荐

  1. 加载usbserial驱动后,为什么adb不可用了?

    ​某设备提供了USB串口功能,上位机(Host端)可以通过USB串口与之通信.对于Linux上位机,比如Ubuntu,自带usbserial驱动,当安装usbserial驱动后,上位机就会生成ttyU ...

  2. MSSQL·查看数据库编码格式

    阅文时长 | 0.67分钟 字数统计 | 837.6字符 主要内容 | 1.引言&背景 2.声明与参考资料 『MSSQL·查看数据库编码格式』 编写人 | SCscHero 编写时间 | 20 ...

  3. SQLFlow数据流分析工具的job功能介绍

    SQLFlow是一款专业的数据血缘关系分析工具,在大型数据仓库中,完整的数据血缘关系可以用来进行数据溯源.表和字段变更的影响分析.数据合规性的证明.数据质量的检查等. 一.SQLFlow 是怎样工作的 ...

  4. 【Mysql】数据库事务,脏读、幻读、不可重复读

    一.什么是数据库事务 数据库事务( transaction)是访问并可能操作各种数据项的一个数据库操作序列,这些操作要么全部执行,要么全部不执行,是一个不可分割的工作单位.事务由事务开始与事务结束之间 ...

  5. 通过Dapr实现一个简单的基于.net的微服务电商系统(十四)——开发环境容器调试小技巧

    之前有很多同学提到如何做容器调试,特别是k8s环境下的容器调试,今天就讲讲我是如何调试的.大家都知道在vs自带的创建项目模板里勾选docker即可通过F5启动docker容器调试.但是对于启动在k8s ...

  6. [刷题] 3 Longest Substring Without Repeating Character

    要求 在一个字符串中寻找没有重复字母的最长子串 举例 输入:abcabcbb 输出:abc 细节 字符集?字母?数字+字母?ASCII? 大小写是否敏感? 思路 滑动窗口 如果当前窗口没有重复字母,j ...

  7. [DB] HDFS

    体系架构 NameNode HDFS主节点.管理员 接收客户端(命令行.Java程序)的请求:创建目录.上传.下载.删除数据 管理和维护HDFS的日志和元信息 日志文件(edits文件) 二进制文件, ...

  8. 关于jmeter线程组和循环次数的设置

    初始设置:设置线程数 n = 80,循环次数a = 1,ramp-up period=5 一 计算最后一个线程的生成时间(last) 总共生成80个线程,总共需要5秒,每秒钟会启动16个线程,所以,第 ...

  9. IIS 10 设置FTP Passive Mode 固定端口

    1. Run [Start] - [Server Manager] and Click [Tools] - [Internet Information Services (IIS) Manager]. ...

  10. 11.16-18 lsci、ipcs、ipcrm:清除ipc相关信息

    lspci:显示所有PCI设备 lspci命令用来显示系统中的所有PCI总线设备或是连接到该总线上的所有设备. lspci命令的参数选项及说明 -v     显示详细信息 -vv    显示更详细的信 ...