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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

four

發布時間:2025/7/14 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 four 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

7月10日

sequence|sequence.in|sequence.out

?

題目描述:

給定一個整數K和長為N的數列{Ai},求有多少個子串(不含空串)的和為K的倍數。(在這里子串表示{A[i]..A[j]},i<=j)

?

輸入格式:

共兩行

第一行 兩個整數N,K

第二行 N個整數表示數列{Ai}

?

輸出格式:

一行一個整數 表示滿足條件的子串的個數

?

樣例輸入:

6 3

1 2 6 3 7 4

?

樣例輸出:

7

?

數據范圍:

20%??? N<=100

對另外20%? K<=100

對所有數據? N<=500000? K<=500000

保證輸入數據中所有數都能用longint保存

?

#include<cstdio> #include<cstring> #include<iostream> #define PROC "sequence" using namespace std; const int MAXN = 500000+5; int x,n,k; int a[MAXN],rest[MAXN]; long long ans = 0; int main() { ??? scanf("%d%d",&n,&k); ??? a[0] = 0; ??????? for (int i = 1;i<=n;i++) ???? { ?????????????????????? scanf("%d",&x); ?????????????????????? int yushu = (x % k+k) %k; ?????????????????????? a[i] = (yushu + a[i-1]%k+k) % k; ??????? } ??????? for (int i = 1;i<=n;i++) ??????? ? rest[a[i]]++; ??????? ans += rest[0]; ???? long long t; ??????? for (int i = 0;i<k;i++) ?????????????? ? if (rest[i]!=0 && rest[i]!=1) ?????????????? ? { ?????????????? ?? t = rest[i]; ?????????????? ?? ans += (t * (t-1)/2); ?????????????? ? } ??????? cout<<ans; ??????? return 0; }

錯因:

1.正解:余數 前綴和組合

做:反應較快 5分鐘

改:沒有注意到500000的平方會超longint

得:注意數據規模 especially 負數 和 計算過程中產生的大數據

2.未完待續

3.未完待續

s��ln�/ `��le='font-size:10.5pt;font-family:"Courier New";color:darkred;mso-ansi-language: FR'>()

{ ??????? ??????? scanf("%d",&n); ??????? for (int i = 1; i<=n; i++) ??????? scanf("%d",&b[i]); ??? sort(b+1,b+n+1); ??? int count = 0,now = b[1]; ??? a[++count] = now; ??? int ans = 0; ??????? for (int i = 2;i<=n;i++) ??????? { ???? if (b[i]!= now) { ?????????????????????? now = b[i]; ?????????????????????? a[++count] = now; ???? } ???? else ans ++; ??? } ???? int max = a[1]; ???? memset(dp, 0x3f3f,sizeof(dp)); ???? for (int i = 1;i<=count;i++) ???? { ??????? dp[a[i]] = 1; ??????? if (a[i]>max)? max = a[i]; ??????? } ??????? for (int i = 1;i<=count;i++) ??????? ? for (int j = 1;j<=max;j++) ??????? ?? { ?????????????????????? int cur = gcd(a[i],j); ?????????????????????? if (dp[cur]>dp[j]+1) dp[cur] = dp[j] + 1; ??????? ?? } ??????? int g = a[1]; ??????? for (int i =2;i<=count;i++) ??????? ? g = gcd(g,a[i]); ??????? printf("%d",count-dp[g]+ans); ??????? return 0; }

錯因:

1.正解:DP: dp[i]表示使得最大公約數是i最小使用多少數。

???????????? 對于每個i枚舉所有數,進行更新。

理由:1.gcd滿足“交換律結合律”。

????? 2. 更新結果與搜索順序無關。

做:審題:誤把gcd當成了最大公因數。

改:no problem

得:縝密審題? 動態思維

2.未完待續

3.未完待續

轉載于:https://www.cnblogs.com/rubylan/p/3836801.html

總結

以上是生活随笔為你收集整理的four的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: a级黄色录像 | 999精品免费视频 | 动漫精品一区二区三区 | av网站在线观看不卡 | 精品一区二区三区四区视频 | 久热久操| 国产ts系列 | 天堂资源在线观看 | 国产专区第一页 | 日韩欧美在线观看一区二区三区 | 丰满少妇在线观看资源站 | 99色影院| 精品丰满少妇一区二区三区 | 精品在线一区 | 成人性生交7777 | 欧美激情网站 | 亚洲视频福利 | 亚洲aⅴ乱码精品成人区 | 天天爽夜夜爽一区二区三区 | 日批视频在线 | 亚洲欧美国产另类 | 亚洲一区二区视频在线播放 | 久久久久一| 秋霞精品一区二区三区 | 激情网页 | 99精品中文字幕 | 美女av网站 | 亚洲 日本 欧美 中文幕 | 国产麻豆剧果冻传媒白晶晶 | 毛片随便看 | 美女裸体跪姿扒开屁股无内裤 | 青青在线播放 | 国产亚洲片 | av中文字幕免费观看 | 少妇激情四射 | 午夜视频福利在线观看 | 亚洲欧美一区二区三区久久 | 乱人伦中文字幕 | 精品国产一区二区三 | 美妇av| 黑森林福利视频导航 | 亚洲精品黄色片 | 少妇一边呻吟一边说使劲视频 | 无码粉嫩虎白一线天在线观看 | 亚洲资源站 | 国产拍拍视频 | 国内视频一区二区三区 | 成人av一区二区在线观看 | www.久久艹| 天天综合欧美 | 欧美aaaa视频| 国产99久| 欧美性猛交性大交 | 亚洲美女在线观看 | 亚洲一区二区自偷自拍 | 色在线视频 | 中文字幕亚洲乱码熟女一区二区 | 日韩久久久久久 | 91大神在线观看视频 | 天堂精品久久 | 亚洲人妖在线 | 欧美亚韩一区二区三区 | 成人高潮片免费视频 | 亚洲欧美中文字幕5发布 | av网址在线 | 国产91精品久久久久久久网曝门 | aaa级黄色片| 国产精品久久久久毛片软件 | 日本一区二区三区免费观看 | jjzz在线| 美女日批在线观看 | 亚洲a毛片 | 古代黄色一级片 | 亚洲va久久久噜噜噜久久天堂 | 国产视频97| 青青草免费公开视频 | 免费成人在线观看 | 亚洲一区亚洲二区 | 久久久久高潮 | 99久久久无码国产精品 | 欧美不卡网 | 超碰95在线 | 一区二区三区视频免费在线观看 | 欧美在线一卡 | 欧美精品久久久久久 | 精品产国自在拍 | 久久久久久久麻豆 | 国产香蕉在线观看 | a级全黄 | 亚洲欧美激情小说另类 | 青青操视频在线观看 | 999视频在线播放 | 久草网站 | 国产成人一区二区三区电影 | 高清国产一区二区 | 国产免费无码一区二区视频 | 牛牛在线免费视频 | 亚洲老女人视频 | 一区二区三区视频免费在线观看 |