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, ...
随机推荐
- ahjesus解决win下U盘无法写入的问题
可能是由于不同品牌的U盘出厂时磁盘分区和格式化方式不同而引起的兼容性问题.解决方案如下 启动cmd.输入diskpart,启动DISKPART工具 在DISKPART窗口中输入以下命令: >li ...
- [Architecture Design] 累进式Domain Layer
[Architecture Design] 累进式Domain Layer 前言 本篇的内容大幅度的简化了分析设计.面向对象等等相关知识,用以传达累进式Domain Layer的核心概念.实际开发软件 ...
- ASP.NET MVC 微信公共平台开发之验证消息的真实性
ASP.NET MVC 微信公共平台开发 验证消息的真实性 在MVC Controller所在项目中添加过滤器,在过滤器中重写 public override void OnActionExecuti ...
- Stanford机器学习课程(Andrew Ng)
斯坦福大学机器学习视频教程(附学习笔记,potplay播放器,PPT等资料),很具有学习价值. 链接:http://mooc.guokr.com/note/16274/
- java中判断字符串是否为数字的方法
一: //1.用JAVA自带的函数 public static boolean isNumeric(String str){ for (int i = 0; i < str.length(); ...
- 桥牌笔记:Skill Level 4 D8
西拿黑桃K.A后,转攻小方块. 看来只有一个小红桃失张了.飞方块没有必要冒险.但将牌分布4-0时会有点麻烦.
- java多线程系列5-死锁与线程间通信
这篇文章介绍java死锁机制和线程间通信 死锁 死锁:两个或两个以上的线程在争夺资源的过程中,发生的一种相互等待的现象. 同步代码块的嵌套案例 public class MyLock { // 创建两 ...
- 解决Junit单元测试 找不到类 ----指定Java Build Path
做junit 单元测试时,发现怎么执行都是以前编译过得代码. 最后找到原因了, src/test/java 编译完的.class路径是 Default output folder Default ou ...
- mysql高可用之LVS + KEEPALIVE + MYSQL
1.架构图 注意 (一) Mysql需要把bind-address的配置去掉,否则无法实现虚拟ip访问 (二) 关闭所有linux防火墙:/sbin/iptables –F(可能没用) (三) ...
- yum安装mariadb
安装mysql yum install mariadb mariadb-server MySQL-python mysql-devel Package MySQL-python-1.2.5-1.ibm ...