C. Party Lemonade

这个题目是贪心,开始我以为是背包,不过也不太好背包,因为这个L都已经是1e9了。

这个题目怎么贪心呢?它是因为这里有一个二倍的关系,所以说val[i]=val[i-1]*2

所以利用这个关系,我们可以求出每一个体积的最小的花费。

这个处理完之后,我们就可以开始处理题目中的L了。

这个L,从高位开始枚举,先求出L个中最多并且要小于等于这个最大值可以用的这个物品的数量,然后如果是小于,那么再多选一次,这样肯定会超出体积,

不过这样就保证了大于等于L。

对于下面一个L取完膜之后继续这样处理,最后求出最小值。

#include <cstdio>
#include <cstring>
#include <queue>
#include <cstdlib>
#include <algorithm>
#include <vector>
#include <iostream>
#define inf 0x3f3f3f3f
#define inf64 0x3f3f3f3f3f3f3f3f
using namespace std;
typedef long long ll;
const int maxn = 1e5 + ;
ll val[]; int main()
{
int n;
ll L;
scanf("%d%I64d", &n, &L);
for (int i = ; i <= n; i++) scanf("%I64d", &val[i]);
for (int i = ; i <= n; i++) val[i] = min(val[i], val[i - ] * );
ll ans = inf64, sum = ;
for(int i=n;i>=;i--)
{
ll len = << (i - );
ll num = L / len;
sum += num * val[i];
L %= len;
ans = min(ans, sum + (L > )*val[i]);
}
printf("%I64d\n", ans);
return ;
}

C

B. Dima and a Bad XOR

这个题目其实比较简单,就是找规律,如果找出来了,就很简单了。

首先我发现如果每一行有两个不同的数,那么肯定是可以的,然后lj发现如果最后一行有两个不相同的数,那么肯定也是可以的,最后就可以推出来

如果任意一行有两个数不同,那么肯定也是可以的。

这样子就很简单了。

#include <cstdio>
#include <cstring>
#include <queue>
#include <cstdlib>
#include <algorithm>
#include <vector>
#include <iostream>
#define inf 0x3f3f3f3f
#define inf64 0x3f3f3f3f3f3f3f3f
using namespace std;
typedef long long ll;
const int maxn = 1e5 + ;
int mp[][]; int main() {
int n, m;
scanf("%d%d", &n, &m);
int flag = , mark = ;
for (int i = ; i <= n; i++) {
for (int j = ; j <= m; j++) {
scanf("%d", &mp[i][j]);
if (!flag&&j > && mp[i][j] != mp[i][]) {
flag = i;
mark = j;
}
}
}
if (!flag)
{
int ans = ;
for (int i = ; i <= n; i++) ans ^= mp[i][];
if (ans == ) printf("NIE\n");
else
{
printf("TAK\n");
for (int i = ; i < n; i++) printf("1 ");
printf("1\n");
}
}
else
{
printf("TAK\n");
int ans = ;
for (int i = ; i <= n; i++) ans ^= mp[i][];
if(ans)
{
for (int i = ; i < n; i++) printf("1 ");
printf("1\n");
}
else
{
for(int i=;i<=n;i++)
{
if (i == flag) printf("%d ", mark);
else printf("1 ");
}
printf("\n");
}
}
return ;
}

B

J 牛客假日团队赛1 分组

这个题目其实很不好想,这个是lj一步步引导我才写出来的,

首先这个题目每一个位置可以往后面推出 1~k 所以算一下复杂度是1e7

dp[i]表示以 i 为最后一个值,从 1~i 的最大的分完组之后的和。

所以这个就有刷表法和填表法,

就是从这个状态往后推和每一个状态从前面推过来,第一个很好写,后面那个比较难。

#include <cstdio>
#include <cstring>
#include <queue>
#include <cstdlib>
#include <algorithm>
#include <vector>
#include <iostream>
#define inf 0x3f3f3f3f
#define inf64 0x3f3f3f3f3f3f3f3f
using namespace std;
typedef long long ll;
const int maxn = 1e4 + ;
int dp[maxn];
int a[maxn]; int main()
{
int n, k;
scanf("%d%d", &n, &k);
for (int i = ; i <= n; i++) scanf("%d", &a[i]);
for(int i=;i<=n;i++)
{
int mxx = ;
for(int j=;j<=k;j++)
{
if (i + j > n) break;
mxx = max(mxx, a[i + j]);
dp[i + j] = max(dp[i + j], dp[i] + j * mxx);
//printf("i=%d j=%d dp[%d]=%d\n", i, j, i + j, dp[i + j]);
}
}
printf("%d\n", dp[n]);
return ;
}

1

#include <cstdio>
#include <cstring>
#include <queue>
#include <cstdlib>
#include <algorithm>
#include <vector>
#include <iostream>
#define inf 0x3f3f3f3f
#define inf64 0x3f3f3f3f3f3f3f3f
using namespace std;
typedef long long ll;
const int maxn = 1e4 + ;
int dp[maxn];
int a[maxn]; int main()
{
int n, k;
scanf("%d%d", &n, &k);
for (int i = ; i <= n; i++) scanf("%d", &a[i]);
for(int i=;i<=n;i++)
{
int mxx = ;
for(int j=;j<k;j++)
{
if (i < j + ) break;
mxx = max(mxx, a[i - j]);
dp[i] = max(dp[i],dp[i - j - ] + mxx * (j + ));
// printf("i=%d j=%d dp[%d]=%d dp[%d]=%d\n", i, j, i, dp[i],i-j,dp[i-j]);
// printf("mxx=%d\n", mxx);
}
}
printf("%d\n", dp[n]);
return ;
}

2

dp 20190618的更多相关文章

  1. BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]

    1911: [Apio2010]特别行动队 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 4142  Solved: 1964[Submit][Statu ...

  2. 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...

  3. AEAI DP V3.7.0 发布,开源综合应用开发平台

    1  升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...

  4. AEAI DP V3.6.0 升级说明,开源综合应用开发平台

    AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...

  5. BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]

    1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4026  Solved: 1473[Submit] ...

  6. [斜率优化DP]【学习笔记】【更新中】

    参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...

  7. BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]

    1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 9812  Solved: 3978[Submit][St ...

  8. px、dp和sp,这些单位有什么区别?

    DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...

  9. android px转换为dip/dp

    /** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...

随机推荐

  1. 洛谷 - P4997 - 不围棋 - 并查集 - 模拟

    https://www.luogu.org/problemnew/show/P4997 首先是改变气的定义,使得容易计算,这个很好理解. 然后使用并查集,因为要维护整个连通块的性质. 最后的难点在于, ...

  2. 算法学习--Day9

    继上一次完成最小生成树后,这次我开始准备最短路径的程序. 最短路分为两种算法,第一个为Floyd算法,第二个为Dijkstra. 简单来说,Floyd是以点为参照对象,它使用三层循环求解当前图中所有点 ...

  3. lightoj 1034【强连通+缩点】

    思路: 缩点,计算入度为0点的个数即可: #include<bits/stdc++.h> using namespace std; typedef long long LL; const ...

  4. 根运动 (Root Motion) – 工作原理

    http://blog.csdn.net/myarrow/article/details/45505085 1. 基本概念 在Unity3D动画中,模型的位置.角度经常会发生变化,我们需要决定是否将模 ...

  5. Ruby编程实践

    命令 常量大写 类名和模块名首字母大写,驼峰法,MyClass,Person 方法名小写,ruby中末尾添加符号特殊含义:destroyMethod!表示这个方法具有破坏性:isPrime?表示返回b ...

  6. mysql 5.5.58 tar包安装部署

    环境: centos 7.4 64位 mysql 版本,5.5.58 glibc 64 位版,下载地址:https://dev.mysql.com/downloads/mysql/5.5.html#d ...

  7. 干货:排名前16的Java工具类

    在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法按使用流行度排名,参考数据来源于Github上随机选取的5万个开源项目源码. 一. ...

  8. git 创建分支并关联远程分支

    从master分支,重新拉取出一个新的分支,名字为dev,具体命令如下: 1. 切换到被copy的分支(master),从服务器拉取最新版本 $git checkout master $git pul ...

  9. 字符串匹配,KMP算法

    KMP的详解见:https://segmentfault.com/a/1190000008575379 主要难点在于Next数组的理解,KMP是不需要回溯的匹配算法. #include<iost ...

  10. 小程序video置顶

    page { overflow-y: none; height: 100vh; } .page__hd_media { position: fixed; width:100vw; top:; heig ...