Problem Description
Recall the problem of finding the number of inversions. As in the course, we are given a sequence of nn numbers a1,a2,⋯,ana1,a2,⋯,an, and we define an inversion to be a pair i<ji
ucas river and Longest Ordered Subsequence
今天在ucas oj上面尝试做了两道题
river:二分即可
Description
Two lovely frogs Alice and Bob live by a river. There are several stones in this river. Every morning, they will go to the other side of the river to have fun. They cross the river by jumping from one stone to another. One day, Alice decides to play tricks on Bob. She plans to remove some stones so that there is no “easy jump” for Bob to across the river any more. But she has no idea which stones she should remove. She needs your help.
2518-和为S
题目:
小b有一个01序列A,她想知道A有多少个非空连续子序列和为S。
你能帮帮她吗?
输入
第一行输入一个数n,表示A的长度;
第二行输入n个数‘0’或‘1’,表示A中的元素,以空格隔开;
第三行输入一个非负整数S;
其中0≤S≤n≤30000。
凌波微步
题目:
你在一个二维空间里的(𝑥𝑀𝑒,𝑦𝑀𝑒)位置,你的家在(𝑥𝐻𝑜𝑚𝑒,𝑦𝐻𝑜𝑚𝑒)位置。每一秒钟你可以选择从你当前位置向上下左右四个方向之一移动一个单位。你现在归心似箭,觉得这么走很慢,所幸你有技能“凌波微步”,在这片二维空间中,有3对传送门,每一对传送门以(𝑥𝑠,𝑦𝑠,𝑥𝑡,𝑦𝑡)的形式给出,表示你到达(𝑥𝑠,𝑦𝑠)点就可以发动“凌波微步”技能,花费10秒钟到达(𝑥𝑡,𝑦𝑡)点,相反你也可以花费10秒钟从(𝑥𝑡,𝑦𝑡)点发动“凌波微步”技能到达(𝑥𝑠,𝑦𝑠)点。“凌波微步”技能可以无限多次发动,但只能在所给出的3对传送门之间使用。请问你回家最短用时多少秒。
2673-最短路径
最短路径的裸题,用了nlogn的写法,优先队列,好久没写代码了,中间没bug出乎我的意料,以后每天一题不会落下,加油!
51nod-2562-阿克曼函数
题目:
2656 阿克曼函数
1.0 秒 131,072.0 KB 5 分 1级题
阿克曼(Arkmann)函数 𝐴(𝑚,𝑛) 中,m与n的定义域是非负整数且本题中m<=3,n<=30。
函数的定义为:
𝑎𝑘𝑚(𝑚,𝑛)=⎧⎩⎨⎪⎪𝑛+1𝑎𝑘𝑚(𝑚−1,1)𝑎𝑘𝑚(𝑚−1,𝑎𝑘𝑚(𝑚,𝑛−1))(𝑚=0)(𝑚>0,𝑛=0)(𝑚>0,𝑛>0)
51nod-1884-变换字符串
题目:
有一个字符串S,长度为n,现在要对其作变换。变换的规则如下:对于第i(1<=i<=n)个字符,可以保持不变,或者变换为第i-1个字符(如果有的话)或者第i+1个字符(如果有的话)。
请计算一下最多可以变换出多少种不同的字符串,最后总数对 1000000007(109+7) 取余后输出。
51node-2502-分块
题目:
小b有个长度为n的数组a,她想将这个数组排序。
然而小b很懒,她觉得对整个数组排序太累了,因此她请你将a分成一些块,使得她只需要对每一块分别排序,就能将整个数组排序。
请问你最多能把a分成多少块。
51nod-2627-树的深度大小
现在有一棵n个节点的树,节点1为这棵树的根,求出每个节点的深度以及每个节点的子树中的节点个数。
输入
第1行:一个数字n,表示树中节点的个数。(1<=n<=100000)
第2-n行:每行两个数字u,v,表示u与v之间有一条边。(1<=u,v<=n)
输出
输出n行,每行两个正整数,第i行的第一个正整数表示节点i的深度,第二个正整数表示以节点i为根的子树大小。
51nod-2497-数三角形
占坑。。。明天更。。。加油!!
ps:00:53点交一发
小b有一个仅包含非负整数的数组a,她想知道有多少个三元组(i,j,k),满足i<j<k且a[i],a[j],a[k]可能作为某个三角形的三条边的边长。
输入
第一行输入一个正整数n,表示数组a中元素个数;
第二行n个非负整数,表示a中元素,以空格隔开;
其中0<n≤1000,a中任意元素a[i]满足0≤a[i]≤1000。