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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Codeforces 1480B. The Great Hero(阅读模拟题,注意数据范围和攻击顺序)

發(fā)布時間:2024/4/19 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Codeforces 1480B. The Great Hero(阅读模拟题,注意数据范围和攻击顺序) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

題意

  • 你有一個英雄,攻擊力為A,生命值為B。(沒有經(jīng)驗(yàn)、金幣等機(jī)制,攻擊力與生命值不可提高)
  • 游戲中有n只怪,怪的攻擊力為a[i],生命值為b[i]。
  • 每次你可以選擇一個怪攻擊,攻擊后你的生命值變?yōu)锽-a[i],怪的生命值變?yōu)閎[i]-A。
  • 不論你是否死亡,如果你能消滅所有的怪,獲得勝利。否則失敗。
  • 解題思路

  • 遍歷攻擊所有的怪,模擬場景扣除英雄的血量。
  • 若英雄的血量足以支撐讓所有怪的血量都扣除到小于等于0,則獲得勝利。否則失敗。
  • 注意

  • 數(shù)據(jù)范圍超過了有符號整型的最大值2^31,所以需要用long long。(因?yàn)闆]有用long long導(dǎo)致這道題WA了)
  • 最后攻擊攻擊力最高的怪。因?yàn)闃O端情況最后一只怪只差一刀的情況下,主角只需要1血就可獲得勝利,超過1的血量都是溢出的。這種情況下,最后攻擊攻擊力最高的怪,可以盡量減少血量溢出,最大可能完成任務(wù)。(我最開始想的是按照攻擊力從小到大遍歷,一樣可以AC這道題,但是卻讓時間復(fù)雜度從O(n)變成了O(nlogn))
  • C++ Code (優(yōu)化后)

    #include <bits/stdc++.h> using namespace std; typedef long long ll;int t; ll A, B, n; ll a[100010]; ll b;int main() {ios::sync_with_stdio(false);cin >> t;while (t--) {cin >> A >> B >> n;ll mxA = 0; // 攻擊力最高的怪的攻擊力。 for (int i = 0; i < n; ++i) cin >> a[i], mxA = max(mxA, a[i]);for (int i = 0; i < n; ++i) {cin >> b;B -= (b+A-1)/A*a[i];}// 回退一刀,看最后一刀前英雄的血量是否大于0 B+mxA > 0?puts("YES"):puts("NO");}return 0; }

    C++ Code (優(yōu)化前)

    #include <bits/stdc++.h> using namespace std; typedef long long ll;int t; ll A, B, n;struct node {ll a;ll b; } arr[100010];bool cmp(node x, node y) {return x.a < y.a; }int main() {ios::sync_with_stdio(false);cin >> t;while (t--) {cin >> A >> B >> n;for (int i = 0; i < n; ++i) {cin >> arr[i].a;}for (int i = 0; i < n; ++i) {cin >> arr[i].b;}// 將怪按攻擊力排序 sort(arr, arr + n, cmp);// 不攻擊最后一只怪 int cost = 0;// 默認(rèn)可以勝利,通過血量改變標(biāo)志位 bool flag = true;for (int i = 0; i < n - 1; ++i) {ll num = arr[i].b / A;arr[i].b -= num * A;if (arr[i].b > 0) {num++;arr[i].b -= A;}B -= num * arr[i].a;// 如果血量歸零,則失敗 if (B <= 0){flag = false;break; }}// 特判最后一只怪 int i = n - 1;ll num = arr[i].b / A;arr[i].b -= num * A;if (arr[i].b > 0) {num++;arr[i].b -= A;}B -= num * arr[i].a;// 回退一刀,若最后一刀前血量歸零,則失敗 if (B <= -arr[i].a)flag = false;if (flag)puts("YES");elseputs("NO");}return 0; }

    總結(jié)

    以上是生活随笔為你收集整理的Codeforces 1480B. The Great Hero(阅读模拟题,注意数据范围和攻击顺序)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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