饥饿的牛hhh

链接:https://ac.nowcoder.com/acm/problem/25148
来源:牛客网

题号:NC25148
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 32768K,其他语言65536K
64bit IO Format: %lld
题目描述
Farmer John养了N(1 <= N <= 5,000)头奶牛,每头牛都有一个不超过32位二进制数的正整数编号。FJ希望奶牛们在进食前,能按编号从小到大的顺序排好队,但奶牛们从不听他的话。为了让奶牛们养成这个习惯,每次开饭时,FJ从奶牛中顺序地挑出一些,这些奶牛的编号必须按挑出的顺序递增。然后FJ让被挑出的奶牛们吃饭——其他奶牛就只能饿肚子了。
现在,你得到了这一次开饭前队伍中从前到后所有奶牛的编号。奶牛们想请你计算一下,按照FJ的规定,最多有多少头奶牛能吃上饭?
比如说,有11头奶牛按以下顺序排好了队(数字代表奶牛的编号)
2 5 18 3 4 7 10 9 11 8 15
对于这个队列,最多可以让7头奶牛吃上饭,她们的编号分别为2,3,4,7,10,11,15。队列2,5,3,10,15是不合法的,因为第3头奶牛的编号(3)小于她前面一头奶牛的编号(5)。
输入描述:
第1行: 一个整数,N
第2…?行: 除了最后一行,每一行都包含恰好20个用空格隔开的整数,依次表 示队伍中从前到后的奶牛的编号。如果N不能整除20,那么最后一行包含的数字不到20个
输出描述:
第1行: 输出按照FJ的规定,最多可以挑出的奶牛的数目
示例1
输入
复制
11
2 5 18 3 4 7 10 9 11 8 15
输出
复制
7
我们做过关于最长上升(不下降子序列)的题目,最长公共子序列的题目,最长回文子串的题目,这个最长上升子序列题目直接用STL来做。等价于二分查找:希望以后能熟练使用stl

#include<bits/stdc++.h>
using namespace std;
int a [10000];
int main()
{
	int t; 
	scanf("%d",&t);
	int chang =0 ; 
    for(int i=1 ;i<=t;i++)
    {
    int tem ; 
    scanf("%d",&tem);
    int wei=lower_bound(a,a+chang,tem)-a+1; 
    *lower_bound(a,a+chang,tem)=tem;
    if(wei>chang)chang++; 
	}
	cout<<chang <<endl;
	return 0;  
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值