积木大赛:

  之前没有仔细地想,然后就直接暴力一点(骗点分),去扫每一高度,连到一起的个数,于是2组超时

先把暴力程序贴上来(可以当对拍机)

 #include<iostream>
#include<cstdio>
using namespace std;
FILE *fin = fopen("block.in","r");
FILE *fout= fopen("block.out","w");
int *h;
int n;
int maxHeight = -;
long long times = ;
int main(){
fscanf(fin,"%d",&n);
h = new int[(const int)(n + )];
for(int i = ;i <= n;i++){
fscanf(fin,"%d",&h[i]);
if(h[i] > maxHeight) maxHeight = h[i];
}
char isNew = 0x00;
for(int i = ;i <= maxHeight;i++){
isNew = 0x00;
for(int j = ;j <= n;j++){
if(h[j] >= i && isNew == ){
times++;
isNew = 0x01;
}
if(h[j] < i && isNew== 0x01){
isNew = 0x00;
}
}
}
fprintf(fout,"%ld",times);
}

  然而用样例来举个例子

       *
* *
* * * *
* * * * *
-----------------------------

  当第i列的目标高度比第(i-1)高的时候,很容易发现,需要多耗费(h[i]-h[i - 1])次操作,因为在操作使第(i-1)列达到目标高度时,第i列和目标高度还差

(h[i]-h[i - 1]),每次只能放一层的积木,所以需要多耗费(h[i]-h[i - 1])次操作。

  例如把第一层放满,其它层还需要的高度


           *
* * *
-----------------------------

  这样会很奇怪,为什么第5列还需要放一次呢?那是因为第一次方的区间是[1,5],每次求差相当于把这一块连续的这一块放上积木

从图中可以看出如果h[i] <= h[i - 1]则不用处理,于是我们可以得到如下递推式

       |- f[i - ] ( h[i] <= h[i - 1] )
f[i]=|
|- f[i - ] + ( h[i]-h[i - 1] ) ( h[i] > h[i - 1] )

最后,附上代码,说明长,代码不长:

 #include<iostream>
#include<fstream>
using namespace std;
ifstream fin("block.in");
ofstream fout("block.out");
int buffer[];
int n;
long long result = ;
int main(){
fin>>n;
for(int i = ;i <= n;i++){
fin>>buffer[];
if( buffer[] > buffer[] ) result += buffer[] - buffer[];
buffer[] = buffer[];
}
fout<<result;
return ;
}

积木大赛


花匠:

  这道题最开始用的是DP,虽然没有优化且明知复杂度是O(N2)但还是用它去骗骗分

 #include<iostream>
#include<cstdio>
using namespace std;
FILE *fin = fopen("flower.in","r");
FILE *fout= fopen("flower.out","w");
int *f;
int *f1;
int *h;
int n;
int main(){
fscanf(fin,"%d",&n);
f = new int[(const int)(n + )];
f1 = new int[(const int)(n + )];
h = new int[(const int)(n + )];
for(int i = ;i <= n;i++){
fscanf(fin,"%d",&h[i]);
f[i] = ;
f1[i] = ;
}
for(int i = ;i <= n; i++){
for(int j = i-;j > ;j--){
if(f[j]% == &&h[i]>h[j]){
f[i] = max( f[j] + ,f[i]);
}
if(f1[j]% == &&h[i]<h[j]){
f1[i] = max(f1[j] + ,f1[i]);
}
if(f[j]% == &&h[i]<h[j]){
f[i] = max(f[j] + ,f[i]);
}
if(f1[j]% == &&h[i]>h[j]){
f1[i] = max(f1[j] + ,f1[i]);
}
}
}
int maxv = -;
for(int i = ;i <= n;i++){
maxv = max(f[i],maxv);
maxv = max(f1[i],maxv);
}
fprintf(fout,"%ld",maxv);
return ;
}

  至于最简单、快捷的方法就是找拐点,一个拐点就是一个答案,至于依据嘛,画画图就能理解了

 #include<iostream>
#include<fstream>
#include<cstring>
using namespace std;
ifstream fin("flower.in");
ofstream fout("flower.out");
int n;
int *h;
int result = ;
void init(){
fin>>n;
h = new int[(const int)(n + )];
memset(h, ,sizeof(int)*(n + ));
for(int i = ;i <= n;i++){
fin>>h[i];
}
}
char aFlag = -;
int main(){
init();
for(int i = ;i < n; i++){
if(h[i] > h[i + ] && (aFlag == || aFlag == -) ){
result++;
aFlag = ;
}
if(h[i] < h[i + ] && (aFlag == || aFlag == -) ){
result++;
aFlag = ;
}
}
fout<<result;
return ;
}

花匠-找拐点

noip 2013 提高组 Day2 部分题解的更多相关文章

  1. NOIP 2013 提高组 day2 积木大赛

      积木大赛 描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为 n 的大厦,大厦可以看成由 n 块宽度为1的积木组成,第

  2. noip 2012 提高组 day2 部分题解

    这道题有多种解法,我用的是扩展欧几里得算法求到的答案 #include<iostream> #include<fstream> #include<cstdio> u ...

  3. NOIP 2015 提高组 Day2

    期望得分:100+10+60=170 实际得分:100+10+35=145 http://www.cogs.pro/cogs/page/page.php?aid=16 T1 跳石头 时间限制:1 s  ...

  4. NOIP 2013 提高组 day1 T2 火柴排队 归并 逆序对

    描述 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度.现在将每盒中的火柴各自排成一列,同一列火柴的高度互不相同,两列火柴之间的距离定义为:∑i=1n(ai−bi)2∑i=1n(ai−bi) ...

  5. NOIP 2013提高组day 1 T 1转圈游戏 快速幂

    描述 n 个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n 个位置编号,从0 到 n-1.最初,第 0 号小伙伴在第 0 号位置,第 1 号小伙伴在第 1 号位置,……,依此类推 ...

  6. noip 2013 提高组 day1

    1.转圈游戏: 解析部分略,快速幂就可以过 Code: #include<iostream> #include<fstream> using namespace std; if ...

  7. NOIP 2014 提高组 Day2

    期望得分:100+60+30=190 实际得分:70+60+30=160 https://www.luogu.org/problem/lists?name=&orderitem=pid& ...

  8. NOIP 2013 提高组 洛谷P1967 货车运输 (Kruskal重构树)

    题目: A 国有 nn 座城市,编号从 11 到 nn,城市之间有 mm 条双向道路.每一条道路对车辆都有重量限制,简称限重. 现在有 qq 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情 ...

  9. NOIP 2008提高组第三题题解by rLq

    啊啊啊啊啊啊今天已经星期三了吗 那么,来一波题解吧 本题地址http://www.luogu.org/problem/show?pid=1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们 ...

随机推荐

  1. 查找算法:二分法查找及其python实现案例

    承接上一篇:查找:顺序查找与二分法查找,将二分法更多详细的python实现解题写下笔记. 简单方法 ''' 二分法查找在列表中的用户输入值,返回index 三种情况跳出循环体: LR相邻 LR位置重合 ...

  2. [.NET]解决EMF图像自动放大空白

    在.NET中产生emf主要使用Metafile对象,但在使用过程中会发生图像自动放大,多余空白的问题. 模拟:声明Size(100,100)的区域,并绘制p1(-50,-50)->p2(50,5 ...

  3. 关于HttpServletRequest报红叉的解决办法

    今天导入项目的时候,发现报错了,如题.然后找到了解决办法 解决方法:鼠标右击项目工程——>Build Path——>点击comfigure Build Path进入----->选择j ...

  4. socke+epoll

    读: #define V5CLI_READ_MSG_LEN 1024 char readMsg[V5CLI_READ_MSG_LEN]; ; ; )) > ){ n += nread; }//读 ...

  5. 16 jmeter中的监听器以及测试结果分析

    常用监听器 断言结果.查看结果树.聚合报告.Summary Report.用表格查看结果.图形结果.aggregate graph等 指标分析 -Samples:本次场景中一共完成了多少请求-Aver ...

  6. PHPExcel使用-使用PHPExcel导出文件-导出MySQL数据

    现在数据库里面有一组数据,我们将它按照不同的难度进行分sheet. 首先我们需要写一个mysql的配置文件- db.config.php(utf-8编码) : <?php $dbconfig= ...

  7. Spark Core(三)Executor上是如何launch task(转载)

    1. 启动任务 在前面一篇博客中(Driver 启动.分配.调度Task)介绍了Driver是如何调动.启动任务的,Driver向Executor发送了LaunchTask的消息,Executor接收 ...

  8. Linear Regression Using Least Squares Method 代码实现

    1. 原理 2. Octave function theta = leastSquaresMethod(X, y) theta = pinv(X' * X) * X' * y; 3. Python # ...

  9. testng入门教程11 TestNG运行JUnit测试

    现在,您已经了解了TestNG和它的各种测试,如果现在担心如何重构现有的JUnit代码,那就没有必要,使用TestNG提供了一种方法,从JUnit和TestNG按照自己的节奏.也可以使用TestNG执 ...

  10. Android弹性滑动的三种实现方式

    引言 上一篇文章我们介绍了实现弹性滑动的三种方式,但仅仅是给出了代码片段和方法理论.今天我们结合一个具体的例子来谈一下如何使用这三种方法来实现弹性滑动.今天我们的例子是仿IOS的下拉操作,我们知道An ...