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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

2016级算法期末上机-F.中等·AlvinZH's Fight with DDLs II

發布時間:2025/4/14 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2016级算法期末上机-F.中等·AlvinZH's Fight with DDLs II 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1118 AlvinZH's Fight with DDLs II

思路

中等題,貪心。

理解題意,每次攻擊中,可以使某個敵人生命值-1,自己生命值減去∑存活敵人總攻擊力。

貪心思想,血量少攻擊高的要先消滅,所以以A/L作為參數排序,即將所有的敵人根據A/L從大到小排序。

遍歷一次,對于排序好的敵人,HP減去(總攻擊*該敵人血量),總攻擊減去該敵人攻擊。代碼如下:

HP -= (sumA * H[i].L); sumA -= H[i].A; if(HP <= 0) break;

分析

貪心證明:對于已經排好序的序列,HP總消耗為 \(\sum_{i = 1}^{n}\sum_{j = i}^{n}\left ( H[i].L*H[j].A \right )\)

如果我們交換其中相鄰兩個的位置,位置設為x,y,HP消耗與原來相比,有影響的也只有i=x和i=y兩項,原來是 \(H[x].L*\sum_{j=x}^{n}H[j].A + H[y].L*\sum_{j=y}^{n}H[j].A\) ,而現在變成了\(H[y].L*\sum_{j=x}^{n}H[j].A + H[x].L*\left ( H[x].A+\sum_{j=y+1}^{n}H[j].A \right )\) ,其他未變,后者減去前者,得到\(H[y].L*H[x].A-H[x].L*H[y].A\) ,依照排序來看,有 \(\frac{H[x].A}{H[x].L} \geq \frac{H[y].A}{H[y].L}\) ,所以后者減去前者的值是大于等于0的。

由此可以證明:如果相鄰兩個交換,會導致HP總消耗增加。任何的一個攻擊敵人次序,都可以在已排好序的次序上通過多次上述交換(相鄰,且索引值小的后移)得到,由此可以判斷所有的攻擊次序HP消耗值都大于等于原排序攻擊次列。

貪心得證,至于如何多次交換,可參考冒泡排序過程。

時間復雜度:O(nlgn)。

空間復雜度:O(n)。

參考代碼

/* Author: 朱輝(35)Result: AC Submission_id: 514527Created at: Mon Dec 25 2017 03:09:00 GMT+0800 (CST)Problem: 1118 Time: 4 Memory: 2840 */#include <cstdio> #include <iostream> #include <algorithm> using namespace std;struct Hero {int A, L;bool operator < (const Hero h) const {return 1.0 * A/L > 1.0 * h.A/h.L;} };int n, HP; Hero H[1005];int main() {while(~scanf("%d %d", &n, &HP)){int sumA = 0;//總攻擊力for (int i = 0; i < n; ++i) {scanf("%d %d", &H[i].A, &H[i].L);sumA += H[i].A;}sort(H, H+n);for (int i = 0; i < n; ++i) {HP -= (sumA * H[i].L);sumA -= H[i].A;if(HP <= 0) break;}if(HP > 0) printf("YES\n");else printf("NO\n");} }

轉載于:https://www.cnblogs.com/AlvinZH/p/8215853.html

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

總結

以上是生活随笔為你收集整理的2016级算法期末上机-F.中等·AlvinZH's Fight with DDLs II的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 久久伊人精品 | 国产毛片18 | 丁香婷婷亚洲 | 最近最好的2019中文 | 欧美在线视频免费 | 中文字幕乱视频 | 精品视频免费 | 一区二区三区四区影院 | 国产乱人伦精品一区二区 | 天天亚洲 | 欧美日韩一本 | av在线操| 污到下面流水的视频 | 污黄网站在线观看 | 日韩欧美激情在线 | 久久激情av | 多男调教一女折磨高潮高h 国内毛片毛片毛片毛片毛片 | 欧美黑丝少妇 | ww成人| 国产欧美久久久精品免费 | 另类激情综合 | 午夜三级在线观看 | 三级在线观看网站 | 手机福利在线 | 91jk制服白丝超短裙大长腿 | 成人免费xxxxx在线视频 | 国产精品久久久久一区二区 | 91不卡在线 | 波多野结衣在线看 | 日韩丰满少妇无码内射 | 国产精品视频久久 | 四虎网站在线播放 | 亚洲国产成人在线 | 亚洲精品a| 日韩av在线影院 | 欧美中文视频 | 毛片天堂 | 99久久综合 | 婷婷激情五月 | 亚洲精品天堂在线 | 俺去草| 日韩久久不卡 | 亚洲www色 | 成av人在线观看 | 91av福利| 69精品久久久久久 | 香蕉茄子视频 | 奇米97 | 揄拍自拍 | 色婷婷av一区二区 | 亚洲超碰在线观看 | 一区二区三区久久 | 亚洲 小说区 图片区 | 欧美 日本 国产 | xxxxav| 麻豆精品一区 | www污网站 | 久草最新| 亚洲欧洲综合网 | 色综合天天色 | 毛片在线播放视频 | 超碰在线免费97 | 久久精品国产精品 | 91欧美亚洲| 操操操操操操操操操操 | 日韩三级国产精品 | 国产精品国产三级国产专播精品人 | 日韩黄色视屏 | 日本h漫在线观看 | 国语对白 | 国产视频高清 | 韩国av在线播放 | 国产高潮在线 | 99激情视频 | 色乱码一区二区三区熟女 | 亚洲精品一区二区三区在线 | 久久久久99精品成人片我成大片 | 久久香蕉精品视频 | 国偷自拍 | 欧美另类videosbestsex日本 | 亚洲AV无码国产成人久久 | 五月婷婷六月丁香综合 | 一本之道久久 | 亚洲开心网| 国产成人综合久久 | 欧美裸体xxx | 人人爽人人爽人人爽 | 精品国产精品三级精品av网址 | 欧美少妇激情 | 88国产精品| 风流老熟女一区二区三区 | 男女视频一区二区 | 日韩怡红院 | 成年人免费大片 | 亚洲欧洲在线视频 | 国产免费无码一区二区视频 | 黑人又大又粗又长 | 成人国产免费 | 欧美成人国产精品高潮 |