92分求助,哪里出了问题?
查看原帖
92分求助,哪里出了问题?
43763
Mistysun楼主2021/5/17 19:33
#include<bits/stdc++.h>
using namespace std;
int a[100005],n,num,l,r,mid,x[1000005];
int main()
{
	//n=8;
	while(scanf("%d",&a[++n])==1) x[n]=1;n--;
	//for(int i=1;i<=n;i++)scanf("%d",&a[i]);
	//x[1]=a[1];
	//num=1;
	for(int i=1;i<=n;i++)
	{
		if(num==0||a[i]<=x[num])x[++num]=a[i];
		int l=1,r=num;
		while(l<r)
		{
			mid=(l+r)/2;
			if(x[mid]<=a[i])r=mid;
			if(x[mid]>a[i])l=mid+1;
		}
		x[l]=a[i];
	} 
	//for(int i=1;i<=num;i++)printf("%d ",x[i]);
	printf("%d\n",num);
	num=0;
	memset(x,0,sizeof(x));
	for(int i=1;i<=n;i++)
	{
		if(num==0||a[i]>x[num])x[++num]=a[i];
		int l=1,r=num;
		while(l<r)
		{
			mid=(l+r)/2;
			if(x[mid]>=a[i])r=mid;
			if(x[mid]<a[i])l=mid+1;
		}
		x[l]=a[i];
	} 
	//for(int i=1;i<=num;i++)printf("%d ",x[i]);
	printf("%d\n",num);
	return 0;
} 
2021/5/17 19:33
加载中...