AC日记——导弹拦截 洛谷 P1020 (dp+模拟)
题目描述
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭。由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹。
输入导弹依次飞来的高度(雷达给出的高度数据是不大于30000的正整数),计算这套系统最多能拦截多少导弹,如果要拦截所有导弹最少要配备多少套这种导弹拦截系统。
输入输出格式
输入格式:
一行,若干个正整数最多100个。
输出格式:
2行,每行一个整数,第一个数字表示这套系统最多能拦截多少导弹,第二个数字表示如果要拦截所有导弹最少要配备多少套这种导弹拦截系统。
输入输出样例
389 207 155 300 299 170 158 65
6
2 思路:
LIS+模拟=不难就是恶心
来,上代码:
#include<cstdio>
#include<algorithm> using namespace std; int ai[],f[],ans_max,ans_num=,n,cur_2; int main()
{
//scanf("%d",&n);
//for(int i=1;i<=n;i++) scanf("%d",&ai[i]),f[i]=1;
n=;
while(scanf("%d",&cur_2)==)
{
n++;
f[n]=;
ai[n]=cur_2;
}
for(int i=;i<=n;i++)
{
for(int j=;j<i;j++)
{
if(ai[i]<=ai[j])
{
f[i]=max(f[j]+,f[i]);
}
}
}
for(int i=;i<=n;i++) ans_max=max(ans_max,f[i]);
printf("%d\n",ans_max);
for(int i=;i<=n;i++)
{
if(f[i]!=ans_max) continue;
int cur_1=ans_max;
int now=ai[i];
ai[i]=;
cur_1--;
for(int j=i-;j>;j--)
{
if(cur_1==) break;
if(cur_1==f[j]&&ai[j]>=now) now=ai[j],ai[j]=,cur_1--;
}
break;
}
for(int i=;i<=n;i++)
{
if(ai[i-]==)
{
for(int j=i-;j>;j--) if(ai[j]==) swap(ai[j],ai[j+]);
}
}
int before=n;
n-=ans_max;
while(n!=)
{
ans_num++;
for(int i=;i<=n;i++) f[i]=;
for(int i=;i<=n;i++)
{
for(int j=;j<i;j++)
{
if(ai[i]<=ai[j]) f[i]=max(f[j]+,f[i]);
}
}
ans_max=;
for(int i=;i<=n;i++) ans_max=max(ans_max,f[i]);
for(int i=;i<=n;i++)
{
if(f[i]!=ans_max) continue;
int cur_1=ans_max;
int now=ai[i];
ai[i]=;
cur_1--;
for(int j=i-;j>=;j--)
{
if(cur_1==) break;
if(cur_1==f[j]&&ai[j]>=now) now=ai[j],ai[j]=,cur_1--;
}
break;
}
for(int i=;i<=n;i++)
{
if(ai[i-]==)
{
for(int j=i-;j>;j--) if(ai[j]==) swap(ai[j],ai[j+]);
}
}
n-=ans_max;
}
ans_num+=n;
printf("%d\n",ans_num);
return ;
}
AC日记——导弹拦截 洛谷 P1020 (dp+模拟)的更多相关文章
- AC日记——过河卒 洛谷 1002
题目描述 棋盘上A点有一个过河卒,需要走到目标B点.卒行走的规则:可以向下.或者向右.同时在棋盘上C点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点.因此称之为“马拦过河卒”. ...
- AC日记——寻找道路 洛谷 P2296
题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点连通. 2 .在满足条 ...
- AC日记——铺地毯 洛谷 P1003(水水水水水~)
题目描述 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地毯.一共有 n 张地毯,编号从 1 到n .现在将这些地毯按照编号从小到大的顺序平行于 ...
- AC日记——围栏木桩 洛谷 P2362
围栏木桩 思路: DP: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 2001 int n,m,ai[ma ...
- AC日记——Power收集 洛谷 P3800
Power收集 思路: 单调队列优化dp: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 4005 stru ...
- AC日记——[SDOI2011]消耗战 洛谷 P2495
[SDOI2011]消耗战 思路: 建虚树走树形dp: 代码: #include <bits/stdc++.h> using namespace std; #define INF 1e17 ...
- AC日记——[SDOI2017]相关分析 洛谷 P3707
[SDOI2017]相关分析 思路: 裸线段树: (玄学ac): 代码: #include <bits/stdc++.h> using namespace std; #define max ...
- AC日记——换教室 洛谷 P1850
题目描述 对于刚上大学的牛牛来说, 他面临的第一个问题是如何根据实际情况中情合适的课程. 在可以选择的课程中,有2n节课程安排在n个时间段上.在第 i ( 1≤ i≤n)个时同段上, 两节内容相同的课 ...
- AC日记——合唱队形 洛谷 P1901
题目描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2, ...
随机推荐
- mysql 5.7.15发布
2016-09-06,mysql发布了5.7更新5.7.15,修复的bug数项目之前的版本已经大大减少,说明越来越稳定了.估计再过三四个版本,就会有很多公司开始考虑生产中使用了.
- mysql服务器io等待高定位与分析
这两天发现公司好几台阿里云ECS上的mysql生产服务器繁忙期间io等待高达百分之二三十(估计九成是没有write back),而且确定是mysql进程产生,由于跑的应用过多,开发和维护无法直接确定哪 ...
- angularJS中的$apply(),$digest(),$watch()
$apply()和$digest()在AngularJS中是两个核心概念,但是有时候它们又让人困惑.而为了了解AngularJS的工作方式,首先需要了解$apply()和$digest()是如何工作的 ...
- Vue条件渲染
gitHub地址:https://github.com/lily1010/vue_learn/tree/master/lesson08 一 v-if显示单个元素 注意else只能跟在v-if或者v-s ...
- JavaScript indexOf() 方法和 lastIndexOf() 方法
一,定义和用法 indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置. lastIndexOf() 方法可返回一个指定的字符串值最后出现的位置,在一个字符串中的指定位置从后向前搜索 ...
- Jquery easyui Tree的简单使用
Jquery easyui Tree的简单使用 Jquery easyui 是jQuery EasyUI是一组基于jQuery的UI插件集合,而jQuery EasyUI的目标就是帮助web开发者更轻 ...
- FDO error:Failed to label layer(XXX) for class Default
描述: A column was specified that does not exist. 出现这个问题的原因在于label features 展示的字段不存在或者为空,只要将其勾选去掉或者换个显 ...
- “Stamping” PDF Files Downloaded from SharePoint 2010
http://blog.falchionconsulting.com/index.php/2012/03/stamping-pdf-files-downloaded-from-sharepoint-2 ...
- Oracle学习之简单查询
使用scott用户下的表, 1.查询所有内容SELECT * FROM emp; 2.查询员工信息,包括员工编号,姓名,职位3个信息SELECT empno,ename,job FROM emp; 3 ...
- c语言的简易日历
用c语言编写的简易日历,代码如下: #include <stdio.h> int main(int argc, const char * argv[]) { // insert code ...