日韩性视频-久久久蜜桃-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的全部內容,希望文章能夠幫你解決所遇到的問題。

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