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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

hdu4038贪心(最快上升倍率,好题)

發(fā)布時間:2025/6/17 编程问答 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hdu4038贪心(最快上升倍率,好题) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
題意:
? ? ? 給你n個數(shù),然后有兩種操作 1.給其中的一個數(shù)+1,2.在序列里面增加一個1,然后給你一個m,表示進行了m次操作,最后問你操作之后所有數(shù)乘積最大是多少?


思路:
? ? ?徒弟給我的一個題目,感覺不錯,這個題目細節(jié)比較多,至于難度,感覺還行,值得做一做,大體思路就是模擬,有點貪心的意思,首先我們要看看負數(shù)的個數(shù),如果是奇數(shù)個,那么要把其中的一個絕對值最小的負數(shù),也就是那個最大的負數(shù)變成正數(shù),然后繼續(xù),如果是偶數(shù)個那么直接繼續(xù),接下來我們要把所有的0變成1,然后把所有的1變成2,然后把所有的2變成3,然后如果還有剩余步數(shù),那么我們把他盡可能變成3,然后是2,如果這個時候還剩余怎么辦?在剩余也就是肯定剩一個了,那么我們就把他加到當前的最小的那個數(shù)上,當前最小的那個數(shù)只有兩種可能,要么是3,要么是比三大的數(shù),這個自己想,上面的步驟中如果m在某個環(huán)節(jié)用沒了,那么就停止然后統(tǒng)計答案就行了,下面說下,為什么3是關(guān)鍵呢?
我的想法是這樣,我們可以考慮增加的倍率,如果是0那么+1這個肯定是最優(yōu)的,如果是1增加1也是當前最合適的,因為直接增加一倍,繼續(xù)往下會發(fā)現(xiàn)到3的時候在增加就沒有直接在虛擬出來一個3合適了,大體是下面那樣
1 > 0
2/1 * 2/1 > 2
3/2 * 3/2 * 3/2 > 3
4/3*4/3*4/3*4/3 < 4
我是這么推的 不知道對不對

然后就是細節(jié),各種細節(jié)要注意,比如3^X,這個X目測很大,為了不超時建議快速冪,還有就是數(shù)據(jù)范圍,還有就是負數(shù)取余的問題...


#include<stdio.h> #include<algorithm>#define MOD 1000000007__int64 X[100005];__int64 Pow(__int64 a ,__int64 b) {__int64 c = 1;while(b){if(b&1) c = c * a % MOD;a = a * a % MOD;b /= 2;//printf("%I64d %I64d %I64d*\n" ,a ,b ,c);}return c; }int main () {int t ,n ,cas = 1 ,i;__int64 m ,Ans;scanf("%d" ,&t);while(t--){scanf("%d %I64d" ,&n ,&m);printf("Case %d: " ,cas ++);__int64 sf = 0 ,s0 = 0 ,s1 = 0 ,s2 = 0 ,s3 = 0;__int64 Max= 0 ,Maxid = -1;__int64 Min = 0 ,Minid = -1;for(i = 1 ;i <= n ;i ++){scanf("%I64d" ,&X[i]);if(X[i] >= 3 && Minid == -1 || Min > X[i]){Min = X[i];Minid = i;}if(X[i] < 0){sf ++;if(Max == 0 || Max < X[i])Max = X[i] ,Maxid = i;}if(X[i] == 0) s0 ++;if(X[i] == 1) s1 ++;if(X[i] == 2) s2 ++;}if(sf % 2){if(m <= -Max){X[Maxid] += m;Ans = 1;for(i = 1 ;i <= n ;i ++)Ans = Ans * X[i] % MOD;printf("%I64d\n" ,Ans);continue;}s0 ++ ,m += Max;}else Maxid = -1;if(m >= s0){s1 += s0;m = m - s0;s0 = 0;}else{s1 += m;s0 = s0 - m ;m = 0;}if(m >= s1){s2 += s1;m = m - s1;s1 = 0;}else{s2 += m;s1 = s1 - m ;m = 0;}if(m >= s2){s3 += s2;m = m - s2;s2 = 0;}else{s3 += m;s2 = s2 - m ;m = 0;}s3 += m / 3;s2 += m % 3 / 2;Ans = 1;if(m % 3 % 2){if(s3){s3 --;Ans = 4;}elsefor(i = 1 ;i <= n ;i ++)if(i == Minid) X[i] ++;}if(s0){printf("0\n");continue;}Ans = Ans * Pow(2 ,s2) % MOD * Pow(3 ,s3) % MOD;for(i = 1 ;i <= n ;i ++){if(i == Maxid || X[i] == 0 || X[i] == 1 || X[i] == 2)continue;if(X[i] < 0) X[i] *= -1;Ans = Ans * X[i] % MOD;}printf("%I64d\n" ,Ans);}return 0; }

《新程序員》:云原生和全面數(shù)字化實踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結(jié)

以上是生活随笔為你收集整理的hdu4038贪心(最快上升倍率,好题)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 亚洲欧洲av在线 | 七七久久 | 18在线观看视频 | 欧美 日韩 国产 中文 | 亚洲熟女乱色一区二区三区 | 黄色片18 | 中国女人内谢69xxxx免费视频 | 欧美激情在线一区 | 在线激情| 欧美日韩高清一区二区三区 | 亚洲精品aⅴ中文字幕乱码 国产精品调教视频 | 日本精品国产 | 丰满少妇大力进入 | 欧美精品一区二区蜜臀亚洲 | 日本91av| 在线免费看黄色片 | 神马久久久久久久 | 国产新婚疯狂做爰视频 | 中文日韩在线观看 | 国产免费又黄又爽又色毛 | 91新网站| 不卡中文字幕在线观看 | 朋友人妻少妇精品系列 | 欧美日韩一区二区电影 | aaa一级黄色片 | 99黄色 | 18黄暴禁片在线观看 | 欧美日韩精品一区二区 | 久一视频在线观看 | 日本午夜大片 | 麻豆蜜桃在线观看 | 琪琪在线视频 | 欧美一级久久久 | 久久99伊人 | 女av在线 | 一区二区三区视频免费看 | 美女一区二区三区视频 | 久久99影院 | 国产黄色的视频 | 国产精品999久久久 在线青草 | 成人国产在线视频 | 天天搞夜夜 | 久久免费公开视频 | av制服丝袜在线 | 男人与雌性宠物交啪啪 | 91精品久久人妻一区二区夜夜夜 | xxx一区二区 | 一区二区三区国产av | 精品乱码一区二区三区 | wwwxxx色| 天堂亚洲网 | 美女扒开尿口给男人桶 | 日本不卡久久 | 国产精品mm | 成人午夜视频在线观看 | 黄色a在线 | 美女写真福利视频 | 亚洲精品av在线 | 久久综合久久88 | www毛片 | 日本久久久久久久久久久 | 国产精品815.cc红桃 | 免费的黄色的网站 | 亚洲 小说区 图片区 | 亚洲一区二区三区加勒比 | 亚洲欧洲视频在线观看 | 免费观看的av网站 | 丁香色婷婷 | 亚洲一区免费看 | 色97色| 182tv午夜福利在线观看 | 成人欧美精品 | 国产喷水吹潮视频www | 午夜色片 | 亚洲精品动漫在线观看 | 久久国产视频播放 | 日日狠狠久久偷偷四色综合免费 | 免费看成人av | 亚洲激情在线播放 | 欧美性天天 | 国产乱码视频 | 自拍 偷拍 欧美 | 97精品国产97久久久久久春色 | 日韩国产在线播放 | 日韩在线视频免费观看 | 国产91在线 | 亚洲 | 日韩欧美电影一区二区三区 | yes4444视频在线观看 | 日韩一级黄色片 | 白白色2012年最新视频 | 国产精品欧美在线 | 91xxx在线观看| 91大神在线观看视频 | 欧美日韩中 | 激情视频免费观看 | 亚洲图片激情小说 | 精品在线免费观看 | 国产一区二区网址 | 91啦中文|