P1982 小朋友的数字

有趣的细节题目

题目描述

有 n 个小朋友排成一列。每个小朋友手上都有一个数字,这个数字可正可负。规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值。

作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值。

请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对 p 取模后输出。

对于 100%的数据,1 ≤ n ≤ 1,000,000,1 ≤ p ≤ 10^9,其他数字的绝对值均不超过 10^9。

求的就是1.特征值 2.分数。

特征值:

算法一:

静态前缀和。

直接枚举出所有的情况(两前缀和之差就是一段区间的sum值),取max。顺便取一下因为当前这一位存在意义就是它被取为最大区间的值,否则就应当取之前的special值,以维持它的不下降性质。但是如果想把这种思路优化到的话,是不可以的。例如这组数据:“3 -2 3”,value[2]对于special[1]是没有意义的,但是value[1]+value[2]>0故对于special[3]有意义。

由此引申到算法二

算法二:

这是一个假算法:看做很多个子段和,还有分开的前缀和,但是不能保证每一个值是前面的最大值

算法三:

这不就是最大子段和的入门题吗(某年初赛题)然后再维持一下最大值以及顺序赋值就可以了

分数:

由题面可以得到。并且在中维持不下降的性质(当时,答案可能是;当,答案必为)。那么就容易得到。因为计算过程中有可能爆精度,但又不能马上模,一种是C++中__int128,另一种是当时就能确定(但是!但是!这个方法虽然被很多AC数据采用,但是遇到如:8 66 -511657297 151810723 -588294472 -271526366 58051666 -792123397 -76376854 -36217375 此数据时会计算出错误答案!)。如果坚持正解的话,还是用大整数或者__int128(C++)吧。

“将其绝对值对 p 取模后输出”我是先取绝对值,再按原符号not x + 1 (get到了转相反数的位运算)

另外,模数是个麻烦的问题。最早的时候,我是输入就模、计算就模,但是我忽略了一个非常明显的问题:最大值 模后 不一定最大,就是说这样计算出来的只是模后最大值。所以用以上的“另一种”方法,在确定后开始模数(于是就和大部分程序一样实际上不完全正确;但本题luogu数据(也许就是当年数据)真的非常不全面,就算很多小细节没有完全也能AC)

还有一件事:pas里面longint溢出没有报RE!90分的最后一个点WA就是因为溢出到负数!这操作很神奇

精简后的代码框架就是这样子的

时间: 2024-08-29 03:48:02

P1982 小朋友的数字的相关文章

洛谷 P1982 小朋友的数字(NOIp2013普及组T3)

题目描述 有 n 个小朋友排成一列.每个小朋友手上都有一个数字,这个数字可正可负.规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值. 作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值. 请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对 p 取模后输出. 输入输出格式 输入格式

noip2013普及组 小朋友的数字

P1982 小朋友的数字 题目描述 有 n 个小朋友排成一列.每个小朋友手上都有一个数字,这个数字可正可负.规定每个 小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋 友手上的数字之和的最大值. 作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小 朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人), 小朋友分数加上其特征值的最大值. 请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对 p 取

[NOIP普及2013] 小朋友的数字

我可能今天智商不在线? 读题读不懂? 让我们来看两段的描述: 规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值. 如果你开开心心去写连续子段和,恭喜你~WA了.因为题目的意思是前面任意一个小朋友的数字的最大值(但要要保证连续) 第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值. 如果你看到其特征值产生了疑惑,其到底是当前的小朋友本人,还是选择加的那个小朋友.不

NOIP2013pj小朋友的数字[DP 最大子段和]

描述 有 n 个小朋友排成一列.每个小朋友手上都有一个数字,这个数字可正可负.规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值.作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值.请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对 p 取模后输出. 格式 输入格式 第一行包含两个

小朋友的数字(codevs 3293)

题目描述 Description 有n个小朋友排成一列.每个小朋友手上都有一个数字,这个数字可正可负.规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值.作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值.请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对p取模后输出. 输入描述 

2013小朋友的数字

题目描述 Description 有n个小朋友排成一列.每个小朋友手上都有一个数字,这个数字可正可负.规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值.作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值.请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对p取模后输出. 输入描述 

noip2013小朋友的数字(dp)

题目描述 Description 有n个小朋友排成一列.每个小朋友手上都有一个数字,这个数字可正可负.规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值. 作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值. 请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对p取模后输出. 输入描

小朋友的数字

[题目描述] 有n个小朋友排成一列.每个小朋友手上都有一个数字,这个数字可正可负.规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值.作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值.请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对p取模后输出. [输入描述] 第一行包含两个正

洛谷 P2008 大朋友的数字

P2008 大朋友的数字 题目背景 在NOIP2013的赛场上,常神牛华丽丽的手残了,小朋友的数字一题只得了10分.于是,他要恶搞一下这道题. 题目描述 有一批大朋友(年龄15岁以上),他们每人手上拿着一个数字,当然这个数字只有1位,也就是0到9之间.每个大朋友的分数为在他之前的最长不下降子序列中所有数之和.(这个序列必须以它作为结尾!)如有多个最长不下降子序列,那么取编号字典序最小的.现在告诉你有n个大朋友,以及他们各自的数字,请你求出他们每个人的分数. 输入输出格式 输入格式: 输入文件为b