首页 > 其他分享 >P1637 三元上升子序列

P1637 三元上升子序列

时间:2024-11-09 17:45:52浏览次数:1  
标签:cnt int num maxn P1637 序列 三元 define

P1637 三元上升子序列

简要题意,在一个序列中寻找长度为三的上升子序列

思路

有两种思路

直接法

一种是对于一个树,算一个数左边比他小的数,算右边比他大的数,然后相乘即是该该点处值

算比他大的数,和比他小的数,用树状数组或线段树即皆可

CODE

#include<bits/stdc++.h>
using namespace std;
#define x first
#define y second
#define ll long long 

int n;
const int maxn=1e5+10;
pair<int,int>m[maxn];
int t[maxn<<2];
int num[maxn];
int j[maxn<<2];
int sml[maxn];//比它小的数
int smx[maxn];//比它大的数
void push_up(int p){
	t[p]=t[p<<1]+t[p<<1|1]; 
}
void update(int p,int l,int r,int nl,int nr){
	if(l==r  && nl==l){
		++t[p];
		return ;
	} 
	int mid=(l+r)>>1;
	if(nl<=mid) update(p<<1,l,mid,nl,nr);
	if(nr>mid) update(p<<1|1,mid+1,r,nl,nr);
	push_up(p);
}
ll query(int p,int l,int r,int nl,int nr){
	ll res=0;
	if(nl<=l && r<=nr){
		return t[p];	
	}
	int mid=(l+r)>>1;
	if(nl<=mid) res+=query(p<<1,l,mid,nl,nr);
	if(nr>mid) res+=query(p<<1|1,mid+1,r,nl,nr);
	push_up(p);
	return res;
}
int main(){
	cin>>n;
	for(int i=1;i<=n;++i){
		int x;cin>>m[i].x;
		m[i].y=i;
	}
	sort(m+1,m+1+n);
	int cnt=0;//cnt是离散后的大小 
	for(int i=1;i<=n;++i){
		if(m[i].x>m[i-1].x) ++cnt;
		num[m[i].y]=cnt;//离散化
	}
	for(int i=1;i<=n;++i){
		if(num[i]>1) sml[i]=query(1,1,n,1,num[i]-1);
		update(1,1,n,num[i],num[i]); 
	}
	memset(t,0,sizeof(t));
	for(int i=n;i>=1;--i){
		if(num[i]<n)  smx[i]=query(1,1,n,num[i]+1,n);
		update(1,1,n,num[i],num[i]);
	}
	ll ans=0;
	for(int i=1;i<=n;++i) ans+=(smx[i]*sml[i]);
	cout<<ans<<endl;
	return 0;
}

DP

上升子序列,其实可以让我们很容易相到,最长上升子序列的求法,只需稍加修改即可

令f[i][j]是以a[j]为结尾长度为i的上升子序列

\(f[i][j]=\sum_{k<j,a[k]<a[j]}f[i-1][k]\)

利用桶排序的思想,储存f[i][j],在第a[j]个点,这样在转移只需要求
小于a[j]的和即可

如何高效的统计这个和,则会用到树状数组或线段树

遍历i时

树状数组存的应是f[i-1][k]的和(因此遍历i之后需要清空树状数组)

遍历第j+1个序列时,前j个序列 第a[j]点的位置加上f[i-1][j]

寻找满足状态转移方程则 f[i][j]+=sum(a[j]-1)

#include<bits/stdc++.h>
using namespace std;
#define x first 
#define y second
#define ll long long
int n;
const int maxn=1e5+10;
pair<int,int> m[maxn];
int a[maxn];
int f[5][maxn];
int lowbit(int x){
	return x&(-x);
}
int t[maxn];
void add(int x,int k){
	while(x<=n){
		t[x]+=k;
		x+=lowbit(x);
	}
}
ll sum(int x){
	ll sum=0;
	while(x){
		sum+=t[x];
		x-=lowbit(x);
	}
	return sum;
}
int main(){
	cin>>n;
	for(int i=1;i<=n;++i) {
		cin>>m[i].x;
		m[i].y=i;
	}
	int num=0;
	sort(m+1,m+1+n);
	for(int i=1;i<=n;++i){
		if(m[i].x>m[i-1].x) ++num;
		a[m[i].y]=num;
	}
	for(int i=1;i<=n;++i) f[1][i]=1;
	for(int i=2;i<=3;++i){
		memset(t,0,sizeof(t));
		for(int j=1;j<=n;++j){
			f[i][j]=sum(a[j]-1);
			add(a[j],f[i-1][j]);
		}
	}
	ll ans=0;
	for(int i=1;i<=n;++i) ans+=f[3][i];
	cout<<ans<<endl;
	return 0; 
} 

标签:cnt,int,num,maxn,P1637,序列,三元,define
From: https://www.cnblogs.com/guiyou/p/18537039

相关文章

  • LeetCode128 最长连续序列
    最长连续序列题目链接:LeetCode128描述给定一个未排序的整数数组nums,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。请你设计并实现时间复杂度为O(n)的算法解决此问题。示例输入:nums=[100,4,200,1,3,2]输出:4解释:最长数字连续序列是[1,2,3,4]。它......
  • 【让中国再次伟大】腾讯开源大语言模型Hunyuan-large,支持高达256K文本序列
    腾讯今日发布开源MOE大语言模型Hunyuan-large,总参数量达398B,激活参数量52B。公开测评结果显示,腾讯混元Large在CMMLU、MMLU、CEva1、MATH等多学科综合评测集以及中英文NLP任务、代码和数学等9大维度全面领先,超过Llama3.1、Mixtral等一流的开源大模型。随着人工智能技术的飞......
  • C++算法练习-day38——106.从中序和后序遍历序列构造二叉树
    题目来源:.-力扣(LeetCode)题目思路分析题目要求根据一棵二叉树的中序遍历(inorder)和后序遍历(postorder)结果重建这棵二叉树。中序遍历的特点是左子树->根节点->右子树,而后序遍历的特点是左子树->右子树->根节点。利用这两个遍历的特点,我们可以递归地重建整棵树。后序......
  • Java中序列化与反序列化
    序列化(Serialization)和反序列化(Deserialization)是计算机科学中用于数据存储和传输的两种基本操作。序列化:序列化是将对象的状态信息转换为可以存储或传输的形式的过程。简单来说,就是将对象转换为字节序列(比如JSON、XML等格式)。目的:使得对象可以在网络上进行传输,或者存储到文......
  • 读数据工程之道:设计和构建健壮的数据系统32序列化和云网络
    1. 序列化1.1. 仅仅通过从CSV转换到Parquet序列化,任务性能就提高了上百倍1.2. 基于行的序列化1.2.1. 基于行的序列化是按行来组织数据1.2.2. 对于那些半结构化的数据(支持嵌套和模式变化的数据对象)​,基于行的序列化需要将每个对象作为一个单元来存储1.2.3. CSV格......
  • 【题解】「NOIP2024模拟赛24 T2」子序列们
    【题解】「NOIP2024模拟赛24T2」子序列们https://www.becoder.com.cn/contest/5715/problem/2\(\mathcal{Description}\)给定一个0/1串\(a\),你需要生成一个长度为\(n\)的序列\(b\),其中\(b_i\)为\(a\)的一个子序列,且满足:\(|b_i|=n-i+1\);\(\foralli\in(1,n]\),\(b......
  • 数据分析-44-时间序列预测之深度学习方法TCN
    文章目录1TCN简介1.1网络示意图1.2TCN优点2模拟应用2.1模拟数据2.2预处理创建滞后特征2.3划分训练集和测试集2.4创建TCN模型2.5模型训练2.6模型预测3自定义my_TCN模型3.1my_TCN()函数3.2训练模型3.3模型预测3.4改进4参考附......
  • ue4资产序列化从入门到精通: 第一章 初识序列化
    一、写作目的:(全文字数4926,阅读大约需25min)首先,我有一个相关的需求要做,然后在拜读了网络上各大UE4序列化解析的文章后,发现大都讲的很模糊,对新入序列化大门的小白非常不友好。有的直接贴上一大段代码(好似直接糊脸上的不解释连招),也有的讲着讲着嘎然而止,也有的总是讲一些空洞的理......
  • [题目总结 #1] 静态序列区间查询问题(未完)
    [题目总结#1]静态序列区间查询问题前言不久前遇到一批这种题,我发现自己思路很单一,只想着莫队、分块、线段树,但是其实可能有其他巧妙的做法,而且就算是用分块、线段树维护的东西也有我没想到的。总体来说,在这种题上,自己的思维太固化、自己太依赖思维惯性,又不熟悉各种套路。于是......
  • 11月7日 NOIP模拟(难题math、矩阵游戏matrix、括号序列seq、道路road) - 模拟赛记录
    PrefaceT1试图找规律失败,正经推反而几分钟就出来了。以后应该少想这些歪门邪道(除非实在闲的蛋疼或者没有一点头绪,且必须要打完所有能打的子任务比如暴力或特殊性质;而且必须在用常规方法思考过后,才能够用一些稍微不那么常规的方法)至于T2、T3、T4,因为知道T1浪费了太多时间,都是......