study from:

https://www.cnblogs.com/flashhu/p/9480669.html

1.前缀和

https://www.luogu.org/problemnew/show/P2513

 #include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <time.h>
#include <string>
#include <set>
#include <map>
#include <list>
#include <stack>
#include <queue>
#include <vector>
#include <bitset>
#include <ext/rope>
#include <algorithm>
#include <iostream>
using namespace std;
#define ll long long
#define minv 1e-6
#define inf 1e9
#define pi 3.1415926536
#define E 2.7182818284
const int mod=1e4;//
const int maxn=1e3+; int f[maxn][maxn],tot[maxn]; int main()
{
int n,k,i,j,l;
scanf("%d%d",&n,&k);
f[][]=;
for (i=;i<=n;i++)
{
tot[]=;
l=min(i*(i-)/,k);
for (j=;j<=l;j++)
tot[j]=(tot[j-]+f[i-][j])%mod;
for (j=;j<=l;j++)
f[i][j]=(tot[j]-tot[max(j-i,-)]+mod)%mod;
}
printf("%d",f[n][k]);
return ;
}

https://www.luogu.org/problemnew/show/P2511

 #include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <time.h>
#include <string>
#include <set>
#include <map>
#include <list>
#include <stack>
#include <queue>
#include <vector>
#include <bitset>
#include <ext/rope>
#include <algorithm>
#include <iostream>
using namespace std;
#define ll long long
#define minv 1e-6
#define inf 1e9
#define pi 3.1415926536
#define E 2.7182818284
const int mod=;//
const int maxn=5e4+; int a[maxn],t[maxn],tot[maxn],f[maxn][]; int main()
{
int n,c,x,y,i,j,k,l,r,m,result=;
scanf("%d%d",&n,&c);
c++;
for (i=;i<=n;i++)
scanf("%d",&a[i]);
l=; r=5e7;
while (l<=r)
{
m=(l+r)>>;
j=;
k=;
for (i=;i<=n;i++)
if (a[i]>m)
break;
else if (k+a[i]>m)
{
j++;
k=a[i];
}
else
k+=a[i];
if (i==n+ && j<=c)
r=m-;
else
l=m+;
}
printf("%d ",l); t[]=;
for (i=;i<=n;i++)
t[i]=t[i-]+a[i]; f[][]=;
x=,y=;
for (j=;j<=c;j++)
{
tot[-]=;
for (i=;i<=n;i++)
tot[i]=(tot[i-]+f[i][y])%mod;
//f[i][j] f[][j-1]
k=;
f[][x]=;
for (i=;i<=n;i++)
{
//[k,i)
while (t[i]-t[k]>l)
k++;
f[i][x]=(tot[i-]-tot[k-])%mod;
}
result=(result+f[n][x])%mod;
x=x^;
y=y^;
}
printf("%d",(result+mod)%mod);
return ;
}
/*
5 1
3 3 4 5 3 5 3
1 1 1 1 1
*/

2.单调队列优化

https://www.luogu.org/problemnew/show/P1886

 #include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <time.h>
#include <string>
#include <set>
#include <map>
#include <list>
#include <stack>
#include <queue>
#include <vector>
#include <bitset>
#include <ext/rope>
#include <algorithm>
#include <iostream>
using namespace std;
#define ll long long
#define minv 1e-6
#define inf 1e9
#define pi 3.1415926536
#define E 2.7182818284
const int mod=;//
const int maxn=1e6+; /**
n个数字a[1]-a[n],每个大小为m的区间
最小值和最大值
**/ int a[maxn],x[maxn]; ///x:记录下标 int main()
{
int n,m,i,head,tail;
scanf("%d%d",&n,&m);
for (i=;i<=n;i++)
scanf("%d",&a[i]);
///min
head=,tail=;
///以i作为末尾的区间
for (i=;i<=n;i++)
{ while (head1<=tail1 && x[head1]<=i-m)
head1++;
while (head1<=tail1 && a[x[tail1]]>=a[i])
tail1--; ///每个点入队列一次,最多出队列一次
while (head<=tail && x[head]<=i-m) ///在区间外的数字被剔除,(i-m,i]
head++;
while (head<=tail && a[x[tail]]>=a[i]) ///求区间最小/大值,对于在前面的数,只有数值小/大于后面才有用,否则从右往左被剔除(符号相反,大于等于/小于等于),类似单调栈
tail--;
tail++;
x[tail]=i;
if (i>=m)
printf("%d%c",a[x[head]],i==n?'\n':' ');
} ///max
head=,tail=;
for (i=;i<=n;i++)
{
while (head<=tail && x[head]<=i-m)
head++;
while (head<=tail && a[x[tail]]<=a[i])
tail--;
tail++;
x[tail]=i;
if (i>=m)
printf("%d%c",a[x[head]],i==n?'\n':' ');
}
return ;
}

各种蕴含算法思想的DP - 1的更多相关文章

  1. 各种蕴含算法思想的DP - 2

    study from: https://www.cnblogs.com/flashhu/p/9480669.html 3.斜率dp study from:http://www.cnblogs.com/ ...

  2. 各种蕴含算法思想的DP - 3

    内容中包含 base64string 图片造成字符过多,拒绝显示

  3. AC自动机——多模式串匹配的算法思想

    标准KMP算法用于单一模式串的匹配,即在母串中寻求一个模式串的匹配,但是现在又存在这样的一个问题,如果同时给出多个模式串,要求找到这一系列模式串在母串存在的匹配个数,我们应该如何处理呢? 基于KMP算 ...

  4. 机器学习&数据挖掘笔记(常见面试之机器学习算法思想简单梳理)

    机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理) 作者:tornadomeet 出处:http://www.cnblogs.com/tornadomeet 前言: 找工作时( ...

  5. [转]机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理)

    机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理) 转自http://www.cnblogs.com/tornadomeet/p/3395593.html 前言: 找工作时(I ...

  6. JVM三种垃圾收集算法思想及发展过程

    JVM垃圾收集算法的具体实现有很多种,本文只是介绍实现这些垃圾收集算法的三种思想和发展过程.所有的垃圾收集算法的具体实现都是遵循这三种算法思想而实现的. 1.标记-清除算法 标记-清除(Mark-Sw ...

  7. 基本算法思想Java实现的详细代码

    基本算法思想Java实现的详细代码 算法是一个程序的灵魂,一个好的算法往往可以化繁为简,高效的求解问题.在程序设计中算法是独立于语言的,无论使用哪一种语言都可以使用这些算法,本文笔者将以Java语言为 ...

  8. 基本算法思想之递推算法思想(C++语言描述)

    递推算法是非常常用的算法思想,在数学计算等场合有着广泛的应用.递推算法适合有明显公式规律的场合. 递推算法基本思想 递推算法是一种理性思维莫斯的代表,根据已有的数据和关系,逐步推到而得到结果.递推算法 ...

  9. [算法模版]子序列DP

    [算法模版]子序列DP 如何求本质不同子序列个数? 朴素DP 复杂度为\(O(nq)\).其中\(q\)为字符集大小. \(dp[i]\)代表以第\(i\)个数结尾的本质不同子序列个数.注意,这里对于 ...

随机推荐

  1. vue build,本地正常访问,服务器上,网页一刷新是404,解决办法

    服务器报错如下图: 此原因,是服务器配置的原因,跟build代码本身无关 以ftp为例,在/etc/nginx/conf.d文件夹下,找到xxx.conf,修改成自己需要的路径即可 位置如下两张图:

  2. 对C++多态的一点理解

    作为一个C++新手,我浅谈一下我对多态的一点理解. 首先,引用几句话: 1.继承是一种抽象,它允许程序员在某些时候忽略相似对象的差异,又在其他时候利用这些差异.——<C++沉思录> 2.继 ...

  3. 配置yum,nc,telnet

    一.学习中问题 最近学习在学习Hadoop的一个子项目Zookeeper,在测试其中的“四字命令”---”echo ruok|nc localhost 2181“时发现命令无法被识别,如下图所示: [ ...

  4. [CF1083F]The Fair Nut and Amusing Xor[差分+同余分类+根号分治+分块]

    题意 给定两个长度为 \(n\) 的序列 \(\{a_i\}\) 与 \(\{b_i\}\),你需要求出它们的相似度.,我们定义这两个序列的相似度为将其中一个序列转化为另一个序列所需的最小操作次数.一 ...

  5. SpringCloud+Boot简单例子笔记

    一.spring cloud简介 spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选.分布式会话等等.它运 ...

  6. ESLint 规则详解(二)

    接上篇 ESLint 规则详解(一) 前端界大神 Nicholas C. Zakas 在 2013 年开发的 ESLint,极大地方便了大家对 Javascript 代码进行代码规范检查.这个工具包含 ...

  7. MIT-6.828-JOS-lab3:User Environments

    Lab 3: User Environments实验报告 tags:mit-6.828 os 概述: 本文是lab3的实验报告,主要介绍JOS中的进程,异常处理,系统调用.内容上分为三部分: 用户环境 ...

  8. Python初学者随笔Week1

    Python从入门到放弃 本文主要是描述的是作为初学者对python学习的过程与经历分享,包括一些历程的分享与重要的时间节点记录,对于python学习的笔记与心得. 如果你也是初学者,我们可以一起学习 ...

  9. B. Lost Array

    链接 [http://codeforces.com/contest/1043/problem/B] 题意 自己点开链接看 分析 1到n枚举某个值,判断是否满足并统计 判断方法:假设x序列成立,那么后面 ...

  10. [2017BUAA软工助教]团队beta得分总表

    一.累计得分 项目 α例会 α发布 α测试 α展示 α事后 合计 满分 50 10 10 150 10 230 hotcode5 50 10 9 150 9 228 弗朗明哥舞步 50 10 8 13 ...