nssl1187-排列【dp,随机卡常,树状数组】

正题


题目大意

一个由1∼n1\sim n1n组成的序列
求长度为k的上升序列的个数。
数据保证随机


解题思路

fi,jf_{i,j}fi,j表示长度为i,以j结尾的上升序列个数。
然后
fi,j=∑fi−1,k(aj>ak,j>k)f_{i,j}=\sum f_{i-1,k}(a_j>a_k,j>k)fi,j=fi1,k(aj>ak,j>k)
这是O(n3)O(n^3)O(n3)
我们需要优化,所以我们可以用树状数组,下标表示值。
然后每次加fi−1,jf_{i-1,j}fi1,j进去,然后用查询到a[j]−1a[j]-1a[j]1的前缀和。
这程序就变成了O(n2log2n)O(n^2\ log_2\ n)O(n2 log2 n)
但是依旧不能过,这时我们就要用随机的性质。
因为最长不上升子序列的期望长度为n\sqrt nn个,所以我们可以如果得出该长度的答案为0时,证明这已经是最长的了,所以我们可以以后的都输出0
那么时间复杂度期望为:O(nnlog2n)O(n\sqrt n\ log_2\ n)O(nn log2 n)


code

#pragma GCC optimize(2)
%:pragma GCC optimize(3)
%:pragma GCC optimize("Ofast")
%:pragma GCC optimize("inline")
%:pragma GCC optimize("-fgcse")
%:pragma GCC optimize("-fgcse-lm")
%:pragma GCC optimize("-fipa-sra")
%:pragma GCC optimize("-ftree-pre")
%:pragma GCC optimize("-ftree-vrp")
%:pragma GCC optimize("-fpeephole2")
%:pragma GCC optimize("-ffast-math")
%:pragma GCC optimize("-fsched-spec")
%:pragma GCC optimize("unroll-loops")
%:pragma GCC optimize("-falign-jumps")
%:pragma GCC optimize("-falign-loops")
%:pragma GCC optimize("-falign-labels")
%:pragma GCC optimize("-fdevirtualize")
%:pragma GCC optimize("-fcaller-saves")
%:pragma GCC optimize("-fcrossjumping")
%:pragma GCC optimize("-fthread-jumps")
%:pragma GCC optimize("-funroll-loops")
%:pragma GCC optimize("-fwhole-program")
%:pragma GCC optimize("-freorder-blocks")
%:pragma GCC optimize("-fschedule-insns")
%:pragma GCC optimize("inline-functions")
%:pragma GCC optimize("-ftree-tail-merge")
%:pragma GCC optimize("-fschedule-insns2")
%:pragma GCC optimize("-fstrict-aliasing")
%:pragma GCC optimize("-fstrict-overflow")
%:pragma GCC optimize("-falign-functions")
%:pragma GCC optimize("-fcse-skip-blocks")
%:pragma GCC optimize("-fcse-follow-jumps")
%:pragma GCC optimize("-fsched-interblock")
%:pragma GCC optimize("-fpartial-inlining")
%:pragma GCC optimize("no-stack-protector")
%:pragma GCC optimize("-freorder-functions")
%:pragma GCC optimize("-findirect-inlining")
%:pragma GCC optimize("-fhoist-adjacent-loads")
%:pragma GCC optimize("-frerun-cse-after-loop")
%:pragma GCC optimize("inline-small-functions")
%:pragma GCC optimize("-finline-small-functions")
%:pragma GCC optimize("-ftree-switch-conversion")
%:pragma GCC optimize("-foptimize-sibling-calls")
%:pragma GCC optimize("-fexpensive-optimizations")
%:pragma GCC optimize("-funsafe-loop-optimizations")
%:pragma GCC optimize("inline-functions-called-once")
%:pragma GCC optimize("-fdelete-null-pointer-checks")
#include<cstdio>
#include<cstring>
#include<cctype>
#define BPM (int(1e9)+7)
#define lobit(x) x&-x
#define ll long long
using namespace std;
ll t,n,a[10001],f[301][10001],ans,c[10001];
bool flag=true;
int read() {int x=0,f=1; char c=getchar();while(!isdigit(c)) {if(c=='-')f=-f;c=getchar();}while(isdigit(c)) x=(x<<1)+(x<<3)+c-48,c=getchar();return x*f;
}//快读
void print(int x){if (x>9) print(x/10); putchar(x%10+48); return;
}//快输
void change(ll x,ll a)
{while(x<=n){(c[x]+=a)%=BPM;x+=lobit(x);}
}
ll ask(ll x)
{ll sum=0;while(x){(sum+=c[x])%=BPM;x-=lobit(x);}return sum;
}
int main()
{scanf("%lld",&t);for(ll ti=1;ti<=t;ti++){flag=true;memset(f,0,sizeof(f));n=read();for(ll i=1;i<=n;i++)a[i]=read();for(ll i=1;i<=n;i++)f[1][i]=1;print(n);putchar(' ');for(ll l=2;l<=n;l++){memset(c,0,sizeof(c));ans=0;if(flag)//是否有更长的for(ll i=1;i<=n;i++){f[l][i]=ask(a[i]-1);change(a[i],f[l-1][i]);(ans+=f[l][i])%=BPM;}//动态转移print(ans);if(!ans) flag=0;//没有更长的if(l!=n) putchar(' ');}putchar('\n');}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/323403.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: N O)

今天早上起来原想着学习python的&#xff0c;想看看mysql&#xff0c;于是陷进去了。 明明没碰啊&#xff0c;怎么突然就启动不了了呢 输入mysql net start mysql 一直显示正在启动&#xff0c;最后蹦出个服务无法启动 网上查了下输入 mysqld --initialize 早上的时候输入的…

如何将base64图像数据以图片的形式上传到云存储obs中

大家好&#xff0c;我是雄雄。欢迎关注微信公众号&#xff1a;雄雄的小课堂。 今天分享个方法&#xff0c;如标题所示&#xff1a; 在日常开发中&#xff0c;我们经常会有这样的需求&#xff0c;将前台拿到的base64图像格式的数据&#xff0c;上传到云存储服务器上&#xff0c…

JavaFX鼠标滚动放大缩小图片

一、鼠标滚动放大缩小图片 package cn.util;import java.io.File; import javafx.application.Application; import javafx.beans.value.ChangeListener; import javafx.beans.value.ObservableValue; import javafx.geometry.Point2D; import javafx.geometry.Rectangle2D; i…

linux上还原自主nuget包需要注意的问题

问题的产生的背景 由于我们使用了jenkins进行部署&#xff08;jenkins~集群分发功能和职责处理&#xff09;&#xff0c;而对于.net core项目来说又是跨平台的&#xff0c;所以对它的项目拉取&#xff0c;包的还原&#xff0c;项目的编译和项目的发布都是在一台linux的jenkins节…

ssl提高组国庆模拟赛【2018.10.7】

前言 出现了&#xff01;毒瘤抠题人BPM。 WHF大佬强势串场 成绩 RankRankRankPersonPersonPersonScoreScoreScoreAAABBBCCC1112017myself2017myself2017myself2702702701001001001001001007070702222015hjw2015hjw2015hjw1601601603030301001001003030303332016whf2016whf2016…

python爬虫进阶(初始)

该内容主要是爬虫爬取图片以及html&#xff0c;属于库的基本内容&#xff0c;以后再在此基础上进阶更智能更全面的python代码 整体框架大致 目标&#xff1a; 下载图片 创建文件夹并在文件夹里加入东西 批量下载图片到文件夹里 筛选数据 批量筛选指定数据到文件夹里 将数据导入…

Spring整合mybatis中的sqlSession是如何做到线程隔离的?

转载自 Spring整合mybatis中的sqlSession是如何做到线程隔离的&#xff1f; 项目中常常使用mybatis配合spring进行数据库操作&#xff0c;但是我们知道&#xff0c;数据的操作是要求做到线程安全的&#xff0c;而且按照原来的jdbc的使用方式&#xff0c;每次操作完成之后都要…

Net知识图谱

对于Web系统开发来说&#xff0c;Net其实也是有好多知识点需要学的&#xff0c;虽然目前JAVA是主流&#xff0c;就业市场比较大&#xff0c;但Net也在积极的拥抱开源&#xff0c;大Net Core 2 出来了&#xff0c;这无疑给Net开发者带来更大的希望&#xff0c;好了&#xff0c;以…

域名配置https时,请求无响应的解决方法

大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂。 前言 在项目需要上线时&#xff0c;我们经常会遇到这样的需求&#xff0c;将http的域名换成https&#xff0c;或者当我们使用小程序开发时&#xff0c;只支持https的请求方式&#xff0c…

三步搭建网站

这两天无意中想了解更广泛的编程知识&#xff0c;便去看了些php的视频。我想把本机当成服务器来用&#xff0c;因为事先已经注册了域名&#xff0c;但当我又重新登录腾讯云的时候&#xff0c;上面显示我可以免费领取一个15天的服务器&#xff0c;抱着试一试的心态&#xff0c;领…

USACO2.3【dfs,dp,背包】

正题 T1:最长前缀 LongestPrefixLongest PrefixLongestPrefix 评测记录: https://www.luogu.org/recordnew/lists?uid52918&pidP1470 题目大意 求有字符串集合VVV中的字符可以组成的字符串s的最长前缀。 解题思路 用fif_ifi​表示能否组成长度为i的最长前缀&#xff0c…

jenkins~集群分发功能的具体实现

前一讲主要说了jenkins分发的好处《jenkins~集群分发功能和职责处理》&#xff0c;它可以让具体的节点干自己具体的事&#xff0c;比如windows环境下的节点&#xff0c;它只负责编译&#xff0c;发布windows的生态环境的项目&#xff1b;而linux节点主要负责和它相关的项目&…

一个经典面试题:如何保证缓存与数据库的双写一致性?

转载自 一个经典面试题&#xff1a;如何保证缓存与数据库的双写一致性&#xff1f; 只要用缓存&#xff0c;就可能会涉及到缓存与数据库双存储双写&#xff0c;你只要是双写&#xff0c;就一定会有数据一致性的问题&#xff0c;那么你如何解决一致性问题&#xff1f; 面试题…

让日子充实点

html基础学习&#xff1a;jscsshtml jquery学习 php学习 实在受不了了&#xff0c;学的走火入魔了。我就搞不懂自己和文件的配置较什么劲&#xff0c;为了配置PHP和mysql。我花了太多精力。主要不是在于策略&#xff0c;方法就那一两种&#xff0c;我搞不懂自己为什么就逮这不…

2018NOIP普及组初赛解析

前言 今年因为新政策的原因导致我又得回到普及组 我们东莞的成绩也出来了&#xff0c;虽然本来就是稳进&#xff0c;但是还是要认真对待。 然而我这个菜鸡运气好了点86分 正题 这里就不放题目了&#xff0c;观看本博客之前请拿好初赛试卷 选择题 答案:D 解析:扫描仪是输出设备…

.NET十年回顾

一、 引子 从我还是编程菜鸟时起&#xff0c;.NET就从来没让我失望过。总是惊喜不断。 当年我第一个项目是做个进销存。用的Winform。当时我是机电工程师。编程只是业余心血来潮而已。 .NET的低门槛、VS良好的编程体验及MSDN完善的说明让我从此踏上了码农的不归之路。 回首十…

常用公有云接入——亚马逊

一、什么是 Amazon EC2&#xff1f; Amazon Elastic Compute Cloud (Amazon EC2) 在 Amazon Web Services (AWS) 云中提供可扩展的计算容量。使用 Amazon EC2 可避免前期的硬件投入&#xff0c;因此您能够快速开发和部署应用程序。通过使用 Amazon EC2&#xff0c;您可以根据自…

nssl1191,P2700-逐个击破(平津战役)【并查集】

正题 题目大意 一棵树n个点 有k个点被占领&#xff0c;删除每一条边都有不同的代价&#xff0c;然后要求所以被占领的点相互隔开&#xff0c;代价最小。 解题思路 我们可以考虑反构图&#xff0c;将边权排序&#xff0c;然后对于每条边&#xff0c;如果加入这条边后不会使敌军…

C#生成anb文件

今天我们来看看C#中如何生成anb文件。 这个anb文件本来是要对接别的平台的&#xff0c;人家提供给我们一个协议&#xff0c;然后通过程序来生成&#xff0c;然后对方会根据生成的anb文件进行解析&#xff0c;然后得到心电图啥的。 代码如下&#xff1a; private void create…

开源纯C#工控网关+组态软件

一、 前言 在园子潜水也七八年了。说来惭愧&#xff0c;这么多年虽然一直自称.NET铁杆粉丝&#xff0c;然仅限于回几个不痛不痒的贴&#xff0c;既没有发布过代码&#xff0c;也没有写过文章。 看着.NET和C#在国外风生水起&#xff0c;国内却日趋没落&#xff0c;我也早觉得有…