![](https://img2018.cnblogs.com/blog/1678292/201905/1678292-20190516191930729-945903104.png)
- 朴素解法,复杂度On2,只能过一半的点。
#include<bits/stdc++.h>
using namespace std;
typedef struct{
int num;
int len;
int dlen;
}Missile;
Missile miss[100010];
int cnt=0,n=1,maxnum=0,maxl=0;
int main()
{
while(cin>>miss[n].num){
n++;
}
n--;
for(int i=n;i>=1;i--)
{
for(int j=i;j<=n;j++)
{
if(miss[i].num>=miss[j].num)
{
miss[i].len=max(miss[i].len,miss[j].len+1);
}
if(miss[i].num<miss[j].num)
{
miss[i].dlen=max(miss[i].dlen,miss[j].dlen+1);
}
}
}
for(int i=1;i<=n;i++)
{
cout<<miss[i].len<<" | "<<miss[i].dlen<<endl;
maxl=max(miss[i].len,maxl);
maxnum=max(miss[i].dlen,maxnum);
}
cout<<maxl<<endl<<maxnum+1<<endl;
return 0;
}
- 分析题意可知求一个最长不升子序列,和一个最长上升子序列,转换为LIS线性dp求解,复杂度为Onlogn
#include<bits/stdc++.h>
using namespace std;
int arr[100010],le[100010],gt[100010];
int p1,p2;
int main()
{
int n=1;
while(cin>>arr[n])n++;
n--;
le[1]=gt[1]=arr[1];
p1=p2=1;
for(int i=2;i<=n;i++)
{
if(arr[i]<=le[p1])le[++p1]=arr[i];
else le[upper_bound(le+1,le+p1+1,arr[i],greater<int>())-le]=arr[i];
if(arr[i]>gt[p2])gt[++p2]=arr[i];
else gt[lower_bound(gt+1,gt+p2+1,arr[i])-gt]=arr[i];
}
cout<<p1<<endl<<p2;
return 0;
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
· 如何给本地部署的DeepSeek投喂数据,让他更懂你
· 超详细,DeepSeek 接入PyCharm实现AI编程!(支持本地部署DeepSeek及官方Dee
· 用 DeepSeek 给对象做个网站,她一定感动坏了
· .NET 8.0 + Linux 香橙派,实现高效的 IoT 数据采集与控制解决方案
· .NET中 泛型 + 依赖注入 的实现与应用