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. OpenCV第二课,嵌入MFC

    单纯显示图片,只需链接 opencv_core2411d.libopencv_highgui2411d.lib 1.首先创建一个MFC的dlg,添加Picture Control控件 void CCO ...

  2. 设置上一级controller的backBarButtonItem

    设置上一级controller的backBarButtonItem. self.navigationItem.backBarButtonItem= [[UIBarButtonItem alloc]in ...

  3. 学习Mahout(二)

    继续上一篇博客. 这篇博客介绍如何跑一下mahout自带的Hello world程序 我将mahout 安装在/opt/hadoop/mahout-distribution-0.9 cd /opt/h ...

  4. c++中初始化列表的初始化变量顺序问题

    例题来看:请问下面程序打印出的结果是什么? #include <iostream> #include <string> using namespace std; class b ...

  5. Linux | C代码的编写、运行和调试

    1.  建立.c文件 在终端下输入:vi mytest.c [使用编辑器 vim] 键入键盘i键,使vi编辑器进入编辑模式 接下来在vi编译器中编写代码,如: #include <stdio.h ...

  6. java数据结构----图

    1.图:.在计算机程序设计中,图是最常用的数据结构之一.对于存储一般的数据问题,一般用不到图.但对于某些(特别是一些有趣的问题),图是必不可少的.图是一种与树有些相像的数据结构,从数学意义上来讲,树是 ...

  7. UILabel和UIbutton(富文本)封装方法

    /** 方法说明:设置label的富文本属性 参数说明:contentStr富文本内容 textColor字体颜色 rangeSet设置字体颜色及大小的位置 */ - (UILabel *)backf ...

  8. IBatis.net特性展示代码

    最近公司计划设计新业务平台架构.数据访问层框架要使用ibatis.net.头让我做些例子给其他同事演示下 ibatis的基本特性.然后评估下看是否使用.本来以后上官方下载NPetshop演示下就行了那 ...

  9. Android 仿微信朋友圈添加图片

    github地址(欢迎下载Demo) https://github.com/zhouxu88/WXCircleAddPic 老习惯,先上图,着急用的朋友,直接带走Demo,先拿来用吧,毕竟老板催的紧, ...

  10. eclipse版本要求修改

    eclipse要求打开的是java1.6,而安装的是java1.7,这个时候需要修改配置 找到JAVA的安装路径, 点击前往-电脑-资源库-Java-javaVCirtualMachines-...- ...