9.15 DP合集水表

显然难了一些啊。


凸多边形的三角剖分

瞄了一眼题解。

和蛤蛤的烦恼一样,裸的区间dp。

设f[i][j]表示i~j的点三角剖分最小代价。

显然\(f[i][i+1]=0,f[i][i+2]=w[i]*w[i+1]*w[i+2]\)

然后枚举i,j和哪个点剖。

\[f[l][r]=min(f[l][r],f[l][i]+f[i][r]+w[l]*w[r]*w[i]) (l<i<r)
\]

// It is made by XZZ
#include<cstdio>
#include<algorithm>
#define Fname "division"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
ll w[101],f[101][101];
int main(){
#ifdef xzz
freopen(Fname".in","r",stdin);
freopen(Fname".out","w",stdout);
#endif
int n=gi(),r;
rep(i,1,n)w[i]=w[i+n]=gi();
n*=2;
rep(i,3,n)f[i-2][i]=w[i-2]*w[i-1]*w[i];
rep(siz,4,n/2)drep(l,n-siz+1,1){
r=l+siz-1;
f[l][r]=1e18;
rep(i,l+1,r-1)f[l][r]=min(f[l][r],f[l][i]+f[i][r]+w[l]*w[r]*w[i]);
}
n/=2;
ll ans=2e18;
rep(i,1,n)ans=min(ans,f[i][i+n-1]);
printf("%lld\n",ans);
return 0;
}

求最长公共子序列

字符序列的子序列是指从给定字符序列中随意地(不一定连续)去掉若干个字符(可能一个也不去掉)后所形成的字符序列。

SBT,切掉

// It is made by XZZ
#include<cstdio>
#include<algorithm>
#include<cstring>
#define Fname "lcs"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
char a[5002],b[5002];
int f[5002][5002];
int main(){
#ifdef xzz
freopen(Fname".in","r",stdin);
freopen(Fname".out","w",stdout);
#endif
scanf("%s%s",a+1,b+1);
int lena=strlen(a+1)-1,lenb=strlen(b+1)-1;
rep(i,1,lena)rep(j,1,lenb)
if(a[i]==b[j])f[i][j]=f[i-1][j-1]+1;
else f[i][j]=max(f[i-1][j],f[i][j-1]);
printf("%d\n",f[lena][lenb]);
return 0;
}

卡车更新问题

设f[i][j]表示第i天,上次更新是j就好了

主要难在输出方案,恶心细节多

// It is made by XZZ
#include<cstdio>
#include<algorithm>
#define Fname "truck"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
#define db double
db R[23],U[23],C[23];
db f[23][23];
int g[23][23];
il vd Min(db&a,int&b,db c,int d){if(c>a)a=c,b=d;}
//f[i][j] 到第i天,上次更新是第j天的总回收额max
bool yes[23];
int main(){
#ifdef xzz
freopen(Fname".in","r",stdin);
freopen(Fname".out","w",stdout);
#endif
int n=gi(),k=gi();
rep(i,0,k)scanf("%lf",&R[i]);
rep(i,0,k)scanf("%lf",&U[i]);
rep(i,0,k)scanf("%lf",&C[i]);
rep(i,1,n+1)rep(j,0,k)f[i][j]=-233333.33;
f[1][0]=R[0]-U[0];
rep(i,1,n-1)rep(j,0,i-1){
if(i-j<k)Min(f[i+1][j],g[i+1][j],f[i][j]+R[i-j]-U[i-j],j);
Min(f[i+1][i],g[i+1][i],f[i][j]+R[0]-U[0]-C[i-j],j);
}
int ans=n-1;
rep(i,n-k,n-2)if(f[n][i]>f[n][ans])ans=i;
printf("%.1f\n",f[n][ans]);
int x=n,y=ans;
while(x){
if(y==x-1)yes[x]=1;
y=g[x][y],--x;
}x=n,y=ans;
printf("%d 0 %.1f\n",1,R[0]-U[0]);
y=1;
rep(i,2,n){
if(yes[i])printf("%d 1 %.1f\n",i,R[0]-U[0]-C[y]),y=1;
else printf("%d 0 %.1f\n",i,R[y]-U[y]),++y;
}
return 0;
}

选课

裸的树形背包但要输出方案。GG

不会

为了挽尊,特写spj一个。。。

#include<bits/stdc++.h>
using namespace std;
int main(int argc,char *argv[])
{
FILE *in,*out,*ans,*score,*report;
out=fopen(argv[2],"r");
ans=fopen(argv[3],"r");
score=fopen(argv[5],"w");
report=fopen(argv[6],"w");
int a=-2333,b=-6666;
fscanf(out,"%d",&a);
fscanf(ans,"%d",&b);
if(a==b){
while(fscanf(out,"%d",&a)==1||fscanf(ans,"%d",&b)==1)
if(a!=b){fprintf(score,"3"),fprintf(report,"方案错了。。。3分");return 0;}
fprintf(score,"10"),fprintf(report,"泥太有才了!");
}
else fprintf(score,"0"),fprintf(report,"答案都错了。。。期望%d但输出%d",b,a);
}

没方案或方案错了就会得到3分233

贴一下没方案的代码

// It is made by XZZ
#include<cstdio>
#include<algorithm>
#define Fname "course"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
const int maxn=520,maxm=maxn;
int m,n,w[maxn],fir[maxn],dis[maxm],nxt[maxm],id;
il vd add(int a,int b){nxt[++id]=fir[a],fir[a]=id,dis[id]=b;}
int f[maxn][maxn];
il vd dp(int x,int M){
if(M==0)return;
erep(i,x){
rep(j,1,M-1)f[dis[i]][j]=f[x][j];
dp(dis[i],M-1);
drep(j,M,1)f[x][j]=max(f[x][j],f[dis[i]][j-1]+w[dis[i]]);
}
}
int main(){
freopen(Fname".in","r",stdin);
freopen(Fname".out","w",stdout);
m=gi(),n=gi();
rep(i,1,m)add(gi(),i),w[i]=gi();
dp(0,n);
printf("%d\n",f[0][n]);
return 0;
}

蛤蛤的烦恼

利用了凸多边形的性质。

然而窝不会证。

f[l][r]表示从l开始遍历l~r的最小代价。

g[l][r]表示从r开始遍历l~r的最小代价。

// It is made by XZZ
#include<cstdio>
#include<algorithm>
#include<cmath>
#define Fname "frog"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
#define db double
#define maxn 721
db x[maxn],y[maxn];
db f[maxn][maxn],g[maxn][maxn];
il db dist(int a,int b){return sqrt((x[a]-x[b])*(x[a]-x[b])+(y[a]-y[b])*(y[a]-y[b]));}
int main(){
#ifdef xzz
freopen(Fname".in","r",stdin);
freopen(Fname".out","w",stdout);
#endif
int n=gi(),r;
rep(i,1,n)scanf("%lf%lf",&x[i],&y[i]);
rep(siz,2,n)drep(l,n-siz+1,1){
r=l+siz-1;
f[l][r]=min(f[l+1][r]+dist(l,l+1),g[l+1][r]+dist(l,r));
g[l][r]=min(g[l][r-1]+dist(r-1,r),f[l][r-1]+dist(l,r));
}
printf("%.3f\n",f[1][n]);
return 0;
}

警卫安排

灰常经典乐,以前早写过类似的辣

f[i]表示父亲染i,g表示i染i,h表示i的儿子染i

// It is made by XZZ
#include<cstdio>
#include<algorithm>
#define Fname "security"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
const int maxn=722;
int n,w[maxn];
int fir[maxn],dis[maxn],nxt[maxn],id;
il vd add(int a,int b){nxt[++id]=fir[a],fir[a]=id,dis[id]=b;}
int f[maxn],g[maxn],h[maxn];
//f父亲or自己染自己,g自己染自己,h儿子or自己染自己
il vd dp(int x){
f[x]=0,g[x]=w[x],h[x]=1e9;
int Sum=0;
erep(i,x){
dp(dis[i]);
Sum+=h[dis[i]];
g[x]+=f[dis[i]];
f[x]+=h[dis[i]];
}
erep(i,x)h[x]=min(h[x],Sum-h[dis[i]]+g[dis[i]]);
h[x]=min(h[x],g[x]);
f[x]=min(f[x],g[x]);
}
int isson[maxn];
int main(){
#ifdef xzz
freopen(Fname".in","r",stdin);
freopen(Fname".out","w",stdout);
#endif
n=gi();
int son,s,a,root;
rep(i,1,n){
s=gi();
w[s]=gi();
son=gi();
while(son--)a=gi(),isson[a]=1,add(s,a);
}
rep(i,1,n)if(!isson[i])root=i;
dp(root);
printf("%d\n",min(g[root],h[root]));
return 0;
}

最长上升子序列

SBT。k前去掉比a[k]打的,k后去掉比a[k]小的,显然答案不变而且能取到k

// It is made by XZZ
#include<cstdio>
#include<algorithm>
#define Fname "lis"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
const int maxn=2e5+2;
int d[maxn],a[maxn];
int main(){
#ifdef xzz
freopen(Fname".in","r",stdin);
freopen(Fname".out","w",stdout);
#endif
int s,n=gi(),k=gi(),maxf=0;
rep(i,1,n)a[i]=gi();
d[0]=-2e9;
rep(i,1,n)d[i]=2e9;
rep(i,1,n){
if((i<k&&a[i]>=a[k])||(i>k&&a[i]<=a[k]))continue;
s=lower_bound(d,d+maxf+1,a[i])-d;
//f[i]=s
d[s]=min(d[s],a[i]);maxf=max(maxf,s);
}
printf("%d\n",maxf);
return 0;
}

最短回文串

同编辑距离。稍作改动就行

f[l][r]表示[l,r]变成回文串最少插几个字符

// It is made by XZZ
#include<cstdio>
#include<algorithm>
#define Fname "palindrome"
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
char s[5010];
short f[5010][5010];
int main(){
#ifdef xzz
freopen(Fname".in","r",stdin);
freopen(Fname".out","w",stdout);
#endif
int n=gi(),r;
scanf("%s",s+1);
rep(siz,2,n)drep(l,n-siz+1,1){
r=l+siz-1;
if(s[l]==s[r])f[l][r]=f[l+1][r-1];
else f[l][r]=min(f[l+1][r],f[l][r-1])+1;
}printf("%d\n",f[1][n]);
return 0;
}

水表搞定了!

备份,密码同博客密码

9.15 DP合集水表的更多相关文章

  1. 9.14 DP合集水表

    9.14 DP合集水表 关键子工程 在大型工程的施工前,我们把整个工程划分为若干个子工程,并把这些子工程编号为 1. 2. --. N:这样划分之后,子工程之间就会有一些依赖关系,即一些子工程必须在某 ...

  2. dp合集 广场铺砖问题&&硬木地板

    dp合集 广场铺砖问题&&硬木地板 很经典了吧... 前排:思想来自yali朱全民dalao的ppt百度文库免费下载 后排:STO朱全民OTZ 广场铺砖问题 有一个 W 行 H 列的广 ...

  3. CJOJ 【DP合集】最长上升序列2 — LIS2

    题面 已知一个 1 ∼ N 的排列的最长上升子序列长度为 K ,求合法的排列个数. 好题(除了我想不出来我应该找不到缺点), 想一想最长上升子序列的二分做法, 接在序列后面或者替换. 所以对于每一个位 ...

  4. 【DP合集】棋盘 chess

    给出一张 n × n 的棋盘,格子有黑有白.现在要在棋盘上放棋子,要求: • 黑格子上不能有棋子 • 每行每列至多只有一枚棋子 你的任务是求出有多少种合法的摆放方案.答案模 109+7109+7 . ...

  5. 【CJOJ2499】【DP合集】棋盘 chess

    Description 给出一张 n × n 的棋盘,格子有黑有白.现在要在棋盘上放棋子,要求: • 黑格子上不能有棋子 • 每行每列至多只有一枚棋子 你的任务是求出有多少种合法的摆放方案.答案模 1 ...

  6. 【CJOJ2498】【DP合集】最长上升子序列 LIS

    题面 Description 给出一个 1 ∼ n (n ≤ 10^5) 的排列 P 求其最长上升子序列长度 Input 第一行一个正整数n,表示序列中整数个数: 第二行是空格隔开的n个整数组成的序列 ...

  7. 【DP合集】tree-knapsack

    Description 给出一个 N 个节点的有根树,点编号 1 ∼ N ,编号为 i 的点有权值 v i .请选出一个包含树根的,点数 不超过 K 的连通块,使得点权和最大. Input 输入的第一 ...

  8. 【DP合集】m-knapsack

    给出 n 个物品,第 i 个物品有重量 w i .现在有 m 个背包,第 i 个背包的限重为 c i ,求最少用几个背 包能装下所有的物品. Input 输入的第一行两个整数 n, m ( n ≤ 2 ...

  9. 【DP合集】背包 bound

    N 种物品,第 i 种物品有 s i 个,单个重量为 w i ,单个价值为 v i .现有一个限重为 W 的背包,求能容 纳的物品的最大总价值. Input 输入第一行二个整数 N , W ( N ≤ ...

随机推荐

  1. UVa 10288 - Coupons(数学期望 + 递推)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  2. 9、Dubbo-配置(4)

    本地存根 远程服务后,客户端通常只剩下接口,而实现全在服务器端,但提供方有些时候想在客户端 也执行部分逻辑,比如:做 ThreadLocal 缓存,提前验证参数,调用失败后伪造容错数据等 等,此时就需 ...

  3. 用javascript编写地区表单ES6

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. mpvue微信小程序开发随笔

    mpvue上手很快,学习成本低,目前是开源的,适合技术实力不是很强的公司采用. spring boot 做后台,开发效率杠杠的.建议会java的开发尽量使用spring boot 开发,省事. 最近用 ...

  5. 03_Docker入门(上)之容器创建、容器使用、容器删除

    运维架构服务docker:docker入门 一.确保docker就绪 查看docker程序是否存在,功能是否正常 Docker可执行程序的info命令,该命令会返回所有容器和镜像的数量.Docker使 ...

  6. 面试官问你JS基本类型时他想知道什么?

    面试的时候我们经常会被问答js的数据类型.大部分情况我们会这样回答包括:1.基本类型(值类型或者原始类型): Number.Boolean.String.NULL.Undefined以及ES6的Sym ...

  7. No active profile set, falling back to default profiles: default

    No active profile set, falling back to default profiles: default 这个错误是由于idea没有设置默认启动环境,设置即可

  8. activeMQ的request-response请求响应模式

    一:为什么需要请求响应模式 在消息中间中,生产者只负责生产消息,而消费者只负责消费消息,两者并无直接的关联.但是如果生产者想要知道消费者有没有消费完,或者用不用重新发送的时候,这时就要用到请求响应模式 ...

  9. MongoDB DBA 实践3-----安装mongdb4.0发生错误

    在安装mongodb时,常常会出现一些错误,导致无法安装完全,下面则是各种错误与它们的解决方法: 1.在window机安装mongodb4.0, 其中的一种:由于缺失系统补丁,而导致无法完全安装,具体 ...

  10. Mysql双向同步热备份设置

    1.环境描述. 主机:103.241.49.137(A) 主机:103.240.182.191(B) MYSQL 版本为5.1.112.授权用户.(本人比较懒,直接用的root 跳过这一步)A:mys ...