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

P1637 三元上升子序列

时间:2024-07-21 15:41:16浏览次数:14  
标签:xnow int tree long P1637 序列 三元 include

链接

https://www.luogu.com.cn/problem/P1637

题目

思路

事实上和求逆序对的题目有点像,但是求的是同序对(?。 先回顾下树状数组求逆序对的题目。 https://www.cnblogs.com/zzzsacmblog/p/18314521 这个总的思路其实就是前缀和,只不过拿树状数组优化了。先给每个节点对应的值对应树上的节点+1,然后求比它值小1的前缀和就是数量。

代码

#include<iostream>
#include<vector>
#include<algorithm>
#include<math.h>
#include<sstream>
#include<string>
#include<string.h>
#include<iomanip>
#include<stdlib.h>
#include<map>
#include<queue>
#include<limits.h>
#include<climits>
#include<fstream>
#include<stack>
#define IOS ios::sync_with_stdio(false), cin.tie(0) ,cout.tie(0)
using namespace std;
typedef long long ll;
const int N = 3e4 + 10;
#define int long long
int a[N], b[N];
int tree[N << 2];
int lowbit(int x)
{
	return x & (-x);
}
void add(int x)
{
	int xnow = x;
	while (xnow < N)
	{
		tree[xnow]++;
		xnow += lowbit(xnow);
	}
}
int sum(int x)
{
	int ans = 0;
	int xnow = x;
	while (xnow > 0)
	{
		ans += tree[xnow];
		xnow -= lowbit(xnow);
	}

	return ans;
}
stack<int>st; queue<int>q;
int suma[N];
signed main()
{
	IOS;
	int n; cin >> n;
	for (int i = 1; i <= n; i++)
	{
		cin >> a[i];
		b[i] = a[i];
	}
	sort(b + 1, b + 1 + n);
	//stac
	int cnt = 1;
	map<int, int>small;
	for (int i = 1; i <= n; i++)
	{
		if (!small[b[i]])
			small[b[i]] = cnt++;
	}
	for (int i = 1; i <= n; i++)
		a[i] = small[a[i]];
	for (int i = n; i >= 1; i--)
	{
		add(a[i]);
		st.push(n - i - sum(a[i]) + 1);
	}
	st.pop();
	memset(tree, 0, sizeof(tree));
	for (int i = 1; i <= n; i++)
	{
		add(a[i]);
		q.push(sum(a[i]-1));
	}
	q.pop();
	ll ans = 0;
	for (int i = 2; i < n; i++)
	{
		ans += q.front() * st.top();
		q.pop(), st.pop();
	}
	cout << ans;

	return 0;
}
其中st是求后面的,q是求前面的。遍历的范围是(1,n),两边是开区间。

标签:xnow,int,tree,long,P1637,序列,三元,include
From: https://www.cnblogs.com/zzzsacmblog/p/18314526

相关文章

  • 如何修改 Jupyter Notebook 单元格左侧括号中的数字序列?
    Jupyter在每个单元格的左侧显示一个单元格编号:我想知道为什么JupyterNotebook单元格中的左括号数字序列仅显示奇数。当我更改文件时,它可能显示为偶数,那么如何将数字序列设置为其原始状态呢?JupyterNotebook中左侧括号中的数字序列表示单元格的执行顺序......
  • Chapter 11 Paython数据容器:序列
    欢迎大家订阅【Python从入门到精通】专栏,一起探索Python的无限可能!文章目录前言一、序列的定义二、序列的切片前言在Python中,数据容器是组织和管理数据的重要工具,序列作为其中一种基本的数据结构,具有独特的特性和广泛的应用。本章详细介绍了序列的定义及其切片......
  • DRF如何反序列化json?
    我使用React作为前端,django作为后端。我使用fetchAPI向服务器发送POST请求。数据通过JSON.stringify()传递。该请求将被Django中的视图拦截,数据可在视图函数的请求参数中获取。至少这是我所理解的。现在,当我访问request.body时,我惊讶地得到了一个字典。......
  • 动态规划2:计算最大连续子序列和
    importjava.util.HashMap;importjava.util.Map;publicclassDynamicProgramming2{publicstaticvoidmain(String[]args){int[]arr={3,-4,2,-1,2,6,-5,4};//暴力枚举法System.out.println(getMaxSumSubArr(arr));//加......
  • 去趋势波动分析方法-捕捉时间序列数据在不同尺度上的变化特性
    前言近年来,降水过程中的分形行为和长期相关性成为了一个活跃的研究领域。这些研究表明,降水数据中存在分形行为,但分形理论在实际应用中仍然不够充分。传统方法的局限性:由于降水过程的非平稳性,传统的线性方法(如自相关函数分析或谱分析)在检测时间序列的这些属性时不可靠。非......
  • 基于python的非平稳时间序列模型
    前言平稳时间序列指的是宽平稳时间序列,就是指时间序列的均值、方差和协方差等一二阶矩存在但不随时间改变,表现为时间的常数。若三个条件有一个不成立,那么就称该序列为非平稳时间序列。包括确定性趋势时间序列和随机性趋势时间序列。要想把非平稳的时间序列转化为平稳的时......
  • python中时间序列数据的梯度计算
    我正在尝试编写一个函数,它可以从最适合下面的线返回梯度dataframe在浏览了谷歌的几个资源之后,我仍然不确定这是如何完成的。我明白最佳拟合线的计算公式为:y=mx+b将因变量(y)设置为foos,将自变量(x)设置为DateTimeDatafram......
  • 为什么 NumPy 标量与自定义序列相乘而不与列表相乘?
    我有一个问题要问NumPy专家。考虑一个NumPy标量:c=np.arange(3.0).sum()如果我尝试将它与自定义序列相乘,例如classS:def__init__(self,lst):self.lst=lstdef__len__(self):returnlen(self.lst)def_......
  • YOLOv8改进 | Neck | 注意力尺度序列融合的检测框架ASF-YOLO
    秋招面试专栏推荐:深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转......
  • python反序列化
    之前hgame中遇到python反序列化,这次正好借分享会来尽可能详细学习一下python反序列化基础知识什么是序列化?反序列化?在很多时候为了方便对象传输,我们往往会把一些内容转化成更方便存储、传输的形式。我们把“对象->字符串”的翻译过程称为“序列化”;相应地,把“字符串->对......