HDU3401,列完转移方程拆分一下,正着、反着跑优先队列优化代表买或卖。初始化不大会搞……

 #include <bits/stdc++.h>
using namespace std; const int inf = 0x3f3f3f3f;
const int maxn = ;
int T, n, maxp, w;
int ap, bp, as, bs;
int f[maxn][maxn];
int q[maxn], v[maxn]; int DP() {
for (int j = ; j <= maxp; j++)
f[][j] = -inf;
for (int i = ; i <= w+; i++) {
scanf("%d%d%d%d", &ap, &bp, &as, &bs); for (int j = ; j <= maxp; j++) {
if (j <= as) f[i][j] = -j*ap;
else f[i][j] = -inf;
f[i][j] = max(f[i][j], f[i-][j]);
}
}
for (int i = w+; i <= n; i++) {
scanf("%d%d%d%d", &ap, &bp, &as, &bs); int l = , r = ;
for (int j = ; j <= maxp; j++) {
f[i][j] = f[i-][j];
while (l <= r && f[i-w-][j] + j*ap > v[r]) r--;
q[++r] = j;
v[r] = f[i-w-][j] + j*ap; while (l <= r && q[l] < j-as) l++;
if (l <= r) f[i][j] = max(f[i][j], v[l]-j*ap);
} l = , r = ;
for (int j = maxp; ~j; j--) {
while (l <= r && f[i-w-][j] + j*bp > v[r]) r--;
q[++r] = j;
v[r] = f[i-w-][j] + j*bp; while (l <= r && q[l] > j+bs) l++;
if (l <= r) f[i][j] = max(f[i][j], v[l]-j*bp);
}
}
return f[n][];
} int main() {
for (cin >> T; T; T--) {
cin >> n >> maxp >> w;
cout << DP() << endl;
}
return ;
}

为了少一些痛苦自闭,蒟蒻只好写几道cf水题。

 #include <bits/stdc++.h>
using namespace std; int n; int main() {
while (cin >> n) {
int m = n/;
for (int i = m; i; i--)
if (__gcd(i, n-i) == ) {
printf("%d %d\n", i, n-i);
break;
}
}
return ;
}

854A

 #include <bits/stdc++.h>
using namespace std; int n, k; int main() {
while (cin >> n >> k) {
if (k > && k < n)
printf("1 ");
else printf("0 "); printf("%d\n", min(n - k, *k));
}
return ;
}

854B

优先队列乱模拟一下:

 #include <bits/stdc++.h>
using namespace std; typedef pair<int, int> P;
int n, k;
priority_queue<P> Q;
set<int> minute;
set<int>::iterator it;
int v[];
long long ans; int main() {
cin >> n >> k;
for (int i = ; i <= n; i++) {
int cost;
scanf("%d", &cost);
Q.push(P(cost, i));
minute.insert(i+k);
} for (int i = ; i <= n; i++) {
auto t = Q.top(); Q.pop();
int k1 = t.second;
if (k1 < k) k1 = k;
it = minute.lower_bound(k1);
v[t.second] = *it;
ans += (long long)(*it - t.second) * t.first;
minute.erase(it);
} cout << ans << endl;
for (int i = ; i <= n; i++)
printf("%d ", v[i]);
return ;
}

853A

差分预处理,枚举区间:

 #include <bits/stdc++.h>
#define ll long long
#define ri readint()
#define gc getchar()
#define pb push_back
#define P pair<int, int>
using namespace std; const ll INF = 1e13;
const int maxn = ;
const int maxday = ; int n, m, k;
ll f[maxn];
ll s[maxday+], t[maxday+];
vector<int> from[maxday+], to[maxday+], cost[maxday+]; inline int readint() {
int x = , s = , c = gc;
while (c <= ) c = gc;
if (c == '-') s = -, c = gc;
for (; isdigit(c); c = gc)
x = x* + c - ;
return x * s;
} void init(ll *x, int k) {
for (int i = ; i <= n; i++)
f[i] = INF;
x[k] = INF*n;
} int main() {
cin >> n >> m >> k;
for (int i = ; i < m; i++) {
int day = ri, f = ri, t = ri, c = ri;
from[day].pb(f);
to[day].pb(t);
cost[day].pb(c);
} init(s, );
for (int i = ; i <= maxday; i++) {
s[i] = s[i-];
for (int j = ; j < from[i].size(); j++) {
if (to[i][j] == && cost[i][j] < f[from[i][j]]) {
s[i] -= f[from[i][j]] - cost[i][j];
f[from[i][j]] = cost[i][j];
}
}
}
init(t, maxday+);
for (int i = maxday; i; i--) {
t[i] = t[i+];
for (int j = ; j < from[i].size(); j++) {
if (from[i][j] == && cost[i][j] < f[to[i][j]]) {
t[i] -= f[to[i][j]] - cost[i][j];
f[to[i][j]] = cost[i][j];
}
}
} ll ans = INF;
for (int i = ; i + k <= maxday; i++)
ans = min(ans, s[i-] + t[i+k]);
if (ans > 1e12) puts("-1");
else cout << ans << endl; return ;
}

853B

BZOJ1010,斜率优化dp经典题,推式子很重要,设定不同的函数做法也会有难易区分。

 #include <bits/stdc++.h>
#define db double
#define maxn 50005
using namespace std; int n, L;
int head, tail;
int q[maxn];
db sum[maxn], f[maxn]; db sqr(db x) {
return x * x;
}
db a(int i) {//斜率单调的
return sum[i] + i;
}
db b(int i) {
return sum[i] + i + L + ;
}
db Y(int i) {
return f[i] + sqr(b(i));
}
db slope(int i, int j) {
return (Y(j) - Y(i)) / (b(j) - b(i));
} int main() {
cin >> n >> L;
for (int i = ; i <= n; i++) {
scanf("%lf", &sum[i]);
sum[i] += sum[i-];
}
head = , tail = ;
for (int i = ; i <= n; i++) {
while (head < tail && slope(q[head], q[head+]) < *a(i)) head++;
f[i] = f[q[head]] + sqr(a(i) - b(q[head])); while (head < tail && slope(q[tail-], q[tail]) > slope(q[tail-], i)) tail--;
q[++tail] = i;
}
cout << fixed << setprecision() << f[n] << endl;
return ;
}

#10:wannanewtry——6的更多相关文章

  1. Windows 10:解决开机显示C:\WINDOWS\system32\config\systemprofile\Desktop不可用的方法

      开机显示C:\WINDOWS\system32\config\systemprofile\Desktop不可用应该是不少网友都遇到过. 近日在使用Windows 10 Build 9926中,也出 ...

  2. 【译】ASP.NET MVC 5 教程 - 10:添加验证

    原文:[译]ASP.NET MVC 5 教程 - 10:添加验证 在本节中,我们将为Movie模型添加验证逻辑,并确认验证规则在用户试图使用程序创建和编辑电影时有效. DRY 原则 ASP.NET M ...

  3. Bootstrap入门(十六)组件10:well和具有响应式特性的嵌入内容

    Bootstrap入门(十六)组件10:well和具有响应式特性的嵌入内容 well组件可以为内容增添一种切入效果. 具有响应式特性的嵌入内容可以根据被嵌入内容的外部容器的宽度,自动创建一个固定的比例 ...

  4. RTMPdump(libRTMP) 源代码分析 10: 处理各种消息(Message)

    ===================================================== RTMPdump(libRTMP) 源代码分析系列文章: RTMPdump 源代码分析 1: ...

  5. sed:-e 表达式 #1,字符 10:未终止的“s”命令

    执行shell脚本时,使用sed变量替换指定的字符串,一直出现这个错误: [root@bqh-118 scripts]# vim while_rz.sh [root@bqh-118 scripts]# ...

  6. Module 10:I/O流(java如何实现与外界数据的交流)

    Module 10:I/O流(java如何实现与外界数据的交流) Input/Output:指跨越出了JVM的边界,与外界数据的源头或者目标数据源进行数据交换.               输出   ...

  7. Window 10 :我的性能优化:那效果,杠杠的!

    微软的 windows 10,不错! 当全新安装后,性能总觉得别别扭扭,不那么干净利落. 下面就是我的个人优化措施,期间有很多技术性的操作,如果你没有动手能力,或者是技术小白,可以不用再看了! (1) ...

  8. Window 10 :如何彻底关闭:Windows Defender Service(2015-12-20日更新)

    Window 10 :如何彻底关闭:Windows Defender Service? 网上流传的什么组策略gpeidt.msc方法,什么安装其他的杀软之类的方法都很麻烦,且有弊病! 其实很简单: 利 ...

  9. 搞懂分布式技术10:LVS实现负载均衡的原理与实践

    搞懂分布式技术10:LVS实现负载均衡的原理与实践 浅析负载均衡及LVS实现 原创: fireflyc 写程序的康德 2017-09-19 负载均衡 负载均衡(Load Balance,缩写LB)是一 ...

随机推荐

  1. 整合kxmovie

    下载后发现kxmovie 直接运行是不通的,上面我们已经处理了ffmpeg部分的内容.当然了先处理ffmpeg部分.然后再复制kxmovie/kxmovie到项目中导入相应的文件. 编译报错:UIim ...

  2. codeforces B. George and Round 解题报告

    题目链接:http://codeforces.com/contest/387/problem/B 题目意思:给出1-n个问题,以及要满足是good rounde条件下这n个问题分别需要达到的compl ...

  3. html5--3.18 新增的output元素

    html5--3.18 新增的output元素 学习要点 了解output元素的用法 output元素:数据的输出 output元素是HTML5新增的元素,用来设置不同数据的输出 output元素的输 ...

  4. LDAP解释(转)

    我要着重指出,LDAP是一个数据库,但是又不是一个数据库.说他是数据库,因为他是一个数据存储的东西.但是说他不是数据库,是因为他的作用没有数据库这么强大,而是一个目录. 为了理解,给一个例子就是电话簿 ...

  5. python pickle/cPickle模块

    序列化(picking): 把变量从内存中变成可存储或传输的过程称为序列化,序列化之后,就可以把序列化的对象写入磁盘,或者传输给其他设备; 反序列化(unpickling):相应的,把变量的内容从序列 ...

  6. C++对C的增强

    一.namespace命名空间 1.C++命名空间基本常识所谓namespace,是指标识符的各种可见范围.c++标准程序库中的所有标识符都被定义与一个名为std的namespace中. 1.1:&l ...

  7. Java应用架构设计模块化模式与OSGI摘录

    在Java中,最适合模块化的单元就是Jar文件. 代码层面我们关注的太多了,熟练的开发人员现在很少争论使用模式的好处,也不再识别哪个模式适合当前需要,因为都能够本能地使用各种设计原则和模式,从GoF的 ...

  8. COM组件开发实践(一)

    Preface 因为项目需要,开始从事ActiveX方面的工作,看了一些资料,可惜都是些COM原理方面的,没有切合实际动手的东西,在CodeProject上读完David Marcionek的文章[1 ...

  9. Array 对象

    Array的对象用于在单个的变量中存储多个值. constructor 返回对创建此对象的数组函数的引用. demo: let arr=[];  arr.constructor==Array let ...

  10. 写出高效优美的单片机C语言代码

    程序能跑起来并不见得你的代码就是很好的c代码了,衡量代码的好坏应该从以下几个方面来看 1,代码稳定,没有隐患. 2,执行效率高. 3,可读性高. 4,便于移植. 下面发一些我在网上看到的技巧和自己的一 ...