showcase


私信TA

用户名:1314xcx

访问量:19153

签 名:

等  级
排  名 153
经  验 7031
参赛次数 1
文章发表 70
年  龄 0
在职情况 学生
学  校 霍格沃斯-斯莱特林学院
专  业 计算机科学与技术

  自我简介:

解题思路:


注意事项:

参考代码:

#include<iostream>
#include<algorithm> 
using namespace std;
int a[1001],n;
int b[1001]={0},k=0;
int main()
{
	cin>>n;
	for(int i=1;i<=n;i++)
	 cin>>a[i];
	for(int i=1;i<=n;i++)
	{
		if(a[i]>b[k-1])
		{//如果a[i]大于b数组中的最后一个数 b[k]=a[i]且b数组长度+1 
			b[k++]=a[i];
		}
		else
		{
		  int r=upper_bound(b,b+k,a[i])-b;//二分查找在b中第一个大于a[i]的位置 
		  b[r]=a[i];
		}
	}
	cout<<k<<endl;
	return 0;
}


 

0.0分

1 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区