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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

AtCoder AGC001D Arrays and Palindrome (构造)

發(fā)布時間:2025/3/15 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 AtCoder AGC001D Arrays and Palindrome (构造) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

補一下原來做過的AtCoder思維題的題解

題目鏈接: https://atcoder.jp/contests/agc001/tasks/agc001_d

先特判一些小的情況。

原題就相當于每個回文串對稱的位置連邊,要求圖聯(lián)通。一個長度為\(k\)的回文串,會連\([\frac{k}{2}]\)(中括號下取整)條邊。假設所有回文串(包括\(a\)\(b\))的長度為\(l_i\), 則\(\sum l_i=2n, \sum[\frac{l_i}{2}]\ge 2n-1\), 可得\(\sum (l_i\mod 2)\le 2\), 奇數(shù)長度的回文串不超過\(2\)個。

考慮一種連邊方式: 比如\([1,9]\)是回文串,\([1,8]\)是回文串,那么\(a_9=a_1=a_8=a_2=a_7=a_3=a_6=a_4=a_5\), 很容易得到\(a_1\)\(a_9\)全相等。假設我們再令\([10,17]\)是回文串,\([9,16]\)是回文串,那么\(a_9=a_{16}=a_{11}=a_{14}=a_{13}=a_{12}=a_{15}=a_{10}=a_{17}\), 則\(a_1\)\(a_{17}\)全相等。但是如果我們令\([10,18]\)\([9,17]\),而不是\([10,17]\)\([9,16]\), 那么將得到\(a_9=a_{17}=a_{11}=a_{15}=a_{13}\), 再無法連通。意思就是如果奇數(shù)的放到開頭或者結(jié)尾沒有問題,但是如果放到中間會有問題。那么既然奇數(shù)長度的回文串不超過\(2\)個那么把它們換到開頭結(jié)尾即可。

代碼

#include<cstdio> #include<cstdlib> #include<cstring> #include<algorithm> using namespace std;const int N = 2e5; int a[N+3]; int n,m;int main() {scanf("%d%d",&n,&m); int cnt = 0;for(int i=1; i<=m; i++) {scanf("%d",&a[i]); cnt += (a[i]&1);}if(m==1){if(a[1]==1) printf("1\n1\n1\n");else printf("%d\n2\n%d %d\n",a[1],1,a[1]-1);return 0;}else if(m==2){if(a[1]==1 && a[2]==1) {printf("1 1\n1\n2\n");}else if(a[1]==1) {printf("1 %d\n1\n%d\n",a[2],n);}else {printf("%d %d\n2\n%d %d\n",a[1],a[2],a[1]-1,a[2]+1);}return 0;}if(cnt>2) {printf("Impossible"); return 0;}if(cnt==1){for(int i=1; i<=m; i++) if(a[i]&1) {swap(a[i],a[1]); break;}}else{int flag = 0;for(int i=1; i<=m; i++) if(a[i]&1) {flag++; if(flag==1) swap(a[i],a[1]); else {swap(a[i],a[m]); break;}}}for(int i=1; i<=m; i++) printf("%d ",a[i]); puts("");printf("%d\n",a[1]==1 ? m-1 : m);if(a[1]>1) printf("%d ",a[1]-1);for(int i=2; i<=m; i++) printf("%d ",a[i]+(i==m?1:0)); puts("");return 0; }

總結(jié)

以上是生活随笔為你收集整理的AtCoder AGC001D Arrays and Palindrome (构造)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 粉嫩一区 | 国产精品成人免费精品自在线观看 | 国产美女自慰在线观看 | a级黄色在线观看 | 3d动漫精品啪啪一区二区竹菊 | 国产精品一区二区在线免费观看 | 久久av免费| 亚洲情人网 | 久久九九爱 | 久久精品国产77777蜜臀 | 囯产精品久久久久久 | 噜噜av| 久久老女人 | 色www亚洲国产张柏芝 | 欧美成本人视频 | 成人三级在线视频 | 国产精品jizz在线观看老狼 | 日本美女视频一区 | jizz欧美大片| 国产一级影片 | 亚洲婷婷一区 | 久久一二 | 一级少妇毛片 | 欧美激情一区二区三区四区 | 亚洲青涩| 激情av | 亚洲欧美综合另类自拍 | 国产a级精品 | 一级在线观看 | 免费人妻一区二区三区 | 色婷婷精品 | 免费色片网站 | 美女一二区 | 欧美日韩免费高清一区色橹橹 | 九色视频在线播放 | 在线免费看污片 | 在线观看欧美亚洲 | 337p日本欧洲亚洲大胆张筱雨 | 日韩sese| 亚洲国产精品18久久久久久 | 播放灌醉水嫩大学生国内精品 | 欧美三日本三级少妇99 | 亚洲精品成人a | 欧美日本色| 国产在线青青草 | 97超碰人人澡 | 欧美激情影院 | 欧美浪妇xxxx高跟鞋交 | 日日干夜夜爽 | 欧美变态绿帽cuckold | 私密spa按摩按到高潮 | 国产富婆一级全黄大片 | 国产男人的天堂 | 精品一区二三区 | zoo性欧美| 人人草人人搞 | 国产做受视频 | 欧美大奶在线 | 3d毛片| 国产调教打屁股xxxx网站 | 樱桃国产成人精品视频 | 亚洲精品成人区在线观看 | 中文在线观看视频 | 国产亚洲精品久久久久动 | 久久国产影视 | 日韩电影一区二区 | 一本高清视频 | 国产精品99在线观看 | 亚洲乱码视频在线观看 | 中文字幕+乱码+中文乱 | 亚洲天堂2018av | 欧美日韩综合视频 | 国产美女主播 | 九一成人网 | 超碰在线免费观看97 | 无码毛片aaa在线 | 久久这里只有精品首页 | 男人透女人免费视频 | 亚洲精品日韩丝袜精品 | 另类一区| 天天干天天爽 | 成人在线免费播放视频 | 日韩黄色免费看 | 91亚洲视频 | 综合爱爱网 | 99精品视频免费在线观看 | www.4虎 | 人人爱操 | 电家庭影院午夜 | 国产在线一二区 | 国产免费成人 | 视频一区国产精品 | 国产福利二区 | 魔女鞋交玉足榨精调教 | 成人福利网址 | 青青草在线观看视频 | 美女三级黄色片 | 国产精品国产三级国产传播 | 日本性猛交 |