博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数列 COGS1048:[Citric S2] 一道防AK好题
阅读量:6812 次
发布时间:2019-06-26

本文共 1969 字,大约阅读时间需要 6 分钟。

【题目描述】

Czy手上有一个长度为n的数列,第i个数为xi。

他现在想知道,对于给定的a,b,c,他要找到一个i,使得a*(i+1)*xi2+(b+1)*i*xi+(c+i)=0成立。

如果有多个i满足,Czy想要最小的那个i。

Czy有很多很多组询问需要你回答,多到他自己也不确定有多少组。所以在输入数据中a=b=c=0标志着Czy的提问的结束。

更加糟糕的是,Czy为了加大难度,决定对数据进行加密以防止离线算法的出现。

假设你在输入文件中读到的三个数为a0,b0,c0,那么Czy真正要询问的a=a0+LastAns,b=b0+LastAns,c=c0+LastAns.

LastAns的值是你对Czy的前一个询问的回答。如果这是第一个询问,那么LastAns=0。

所有的询问都将会按上述方式进行加密,包括标志着询问的结束的那个询问也是这样。

 

【输入】

输入文件为 seq.in

输入文件第一行包含一个整数n,表示数列的长度。

输入文件第二行包含n个整数,第i个数表示xi的值。

接下来若干行,每行三个数,表示加密后的a,b,c值(也就是上文所述的a0,b0,c0)

 

【输出】

输出文件为 seq.out

包含若干行,第i行的值是输入文件中第i个询问的答案。注意,你不需要对标志着询问结束的那个询问作答。

同时,标志着询问结束的询问一定是输入文件的最后一行。也就是,输入文件不会有多余的内容。

 

【输入输出样例】

 

seq.in

seq.out

5

-2 3 1 -5 2

-5 -4 145

-1 -6 -509

-9 -14 40

-3 -13 21

-3 -3 -3

5

4

3

3

 

 

【数据范围】

对于40%的数据,满足N<=1000,需要作出回答的询问个数不超过1000.

对于100%的数据,满足N<=50000,需要作出回答的询问个数不超过500000,xi的绝对值不超过30000,解密后的a的绝对值不超过50000,解密后的b的绝对值不超过10^8,解密后的c的绝对值不超过10^18.

【解题思路】

关于这个题目,我只想说一句出题人真心是够了!!!

如果按照丧病的出题人所谓防止出现离线算法在线处理的话复杂度大概是一个O(nq)的,然后能拿40

然而倒着去做这个题目就简单很多……很容易求得最后一个方程的解释-a[n+1],然后代入上一个方程就可以得到一个关于lastans的一次方程,解出这个值在代入……

1 program seq; 2 procedure open; 3 begin 4     assign(input,'seq.in'); 5     assign(output,'seq.out'); 6     reset(input); 7     rewrite(output); 8 end; 9 10 procedure closs;11 begin12     close(input);13     close(output);14 end;15 16 var n,sum,x1,mid,now:int64;17     i:longint;18     a,b,x,lastans,c:array[0..500000] of int64;19 begin20     open;21     read(n);22     for i:=1 to n do23     begin24         read(x[i]);25     end;26     while not eof do27     begin28         inc(sum);29         readln(a[sum],b[sum],c[sum]);30     end;31     //sort(1,n);32     lastans[sum]:=-a[sum];33     for i:=sum-1 downto 2 do34     begin35         now:=lastans[i+1];36         x1:=x[now];37         lastans[i]:=(-(a[i]*(now+1)*sqr(x1)+(b[i]+1)*now*x1+(c[i]+now)))38                     div ((now+1)*sqr(x1)+(now*x1)+1);39 40     end;41     for i:=2 to sum do writeln(lastans[i]);42     closs;43 end.
View Code

 

转载于:https://www.cnblogs.com/wuminyan/p/4896044.html

你可能感兴趣的文章
什么是UV?
查看>>
Stringbuffer与Stringbuilder源码学习和对比
查看>>
Centos 学习大纲
查看>>
常见的JavaScript易错知识点整理
查看>>
RagingWire战略重点批发数据中心服务
查看>>
数据中心的规模是否影响虚拟化DCIM的决策?
查看>>
后流量时代,世间再无电信运营商
查看>>
李开复:钉钉是大胆的突破式创新
查看>>
夏普欲收回美洲品牌授权 海信总裁:严格按照合同办
查看>>
大数据市场迎来扩容期 本土内存数据库抢位崛起
查看>>
IPython4_Notebook
查看>>
rac问题思考总结
查看>>
Android 自定义View总结
查看>>
.NET平台开源项目速览(5)深入使用与扩展SharpConfig组件
查看>>
u-boot-1.3.4 移植到S3C2440
查看>>
HotSpot运行时概览#2
查看>>
Go结构体标签表达式v1.0发布,参数校验杀手锏
查看>>
对react中setState的总结
查看>>
[回炉计划]-实现一个图片预加载
查看>>
正则表达式
查看>>