日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

uestc 1901 方方是个坏孩子

發(fā)布時(shí)間:2024/1/8 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 uestc 1901 方方是个坏孩子 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目的要求重新表述如下:給定數(shù)列 a[1], a[2], ... a[n], 尋找一段連續(xù)的序列[L, R],使得 (a[L] + a[L + 1] + ... + a[R]) mod P = 0。求最長(zhǎng)的序列,即R-L的最大值,無(wú)解輸出1。
首先引入前綴和(Prefix Sum)的概念:
定義 sum[i] = (a[1] + a[2] +... + a[i]) 稱為i位置的前綴和。 (1 <= i <= n),特別的有sum[0] = 0。那么如果某段連續(xù)的[L, R]滿足條件,即元素之和為P的倍數(shù),那么一定有以下結(jié)論成立:
(sum[R] - sum[L - 1]) % P = 0,易證此條件是充要的。
換言之,問題變?yōu)?#xff0c;求相隔最遠(yuǎn)的L和R,滿足 sum[L - 1] 和 sum[R]在模P域下相等,即sum[L - 1] % P == sum[R] % P。

(1 <= L <= R <= n)由于P很小,不超過11,我們開一個(gè)長(zhǎng)度為P的數(shù)組front[P] 和 rear[P],?front[i]代表最小的下標(biāo)x,使得sum[x] % P = i,rear[i]則代表最大的下標(biāo)x滿足相同的條件。
當(dāng)i!=0時(shí),并且(rear[i]&&front[i])都有值,則余數(shù)為i的最長(zhǎng)連續(xù)序列個(gè)數(shù)為rear[i]-front[i];
如果i==0時(shí)的最大長(zhǎng)度是c【i】;最后枚舉從(0——m-1)個(gè)余數(shù),記最大的情況即可; ???????

#include"stdio.h"
#include"string.h"
int main()
{
?int m,n,i,k,h,sum,max;
?int b[12],c[12];
?scanf("%d",&k);
?while(k--)
?{
??scanf("%d%d",&n,&m);
??memset(b,-1,sizeof(b));
??memset(c,-1,sizeof(c));
??sum=0;max=1;
??for(i=1;i<=n;i++)
??{
???scanf("%d",&h);
???sum+=h;
???sum=sum%m;
???if(b[sum]==-1)
????b[sum]=i;
????c[sum]=i;
??}
??for(i=0;i<m;i++)
??{
???if(i==0&&c[i]!=-1)
???{
????? if(max<c[i])
?????max=c[i];
???}
???? ?else if(b[i]&&c[i])
???{????
???? ????? if(max<c[i]-b[i])
??????????? max=c[i]-b[i];
???}
??}
???printf("%d\n",max);
?}
?return 0;
}

總結(jié)

以上是生活随笔為你收集整理的uestc 1901 方方是个坏孩子的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。