《B4051 [GESP202409 五级] 小杨的武器》

📅 2026/7/6 1:12:03
《B4051 [GESP202409 五级] 小杨的武器》
题目背景对应的选择、判断题试题 - GESP 202409 C 五级 - 洛谷有题题目描述小杨有 n 种不同的武器他对第 i 种武器的初始熟练度为 ci​。小杨会依次参加 m 场战斗每场战斗小杨只能且必须选择一种武器使用假设小杨使用了第 i 种武器参加了第 j 场战斗战斗前该武器的熟练度为 ci′​则战斗后小杨对该武器的熟练度会变为 ci′​aj​。需要注意的是aj​ 可能是正数0 或负数这意味着小杨参加战斗后对武器的熟练度可能会提高也可能会不变还有可能降低。小杨想请你编写程序帮他计算出如何选择武器才能使得 m 场战斗后自己对 n 种武器的熟练度的最大值尽可能大。输入格式第一行包含两个正整数 n,m含义如题面所示。第二行包含 n 个整数 c1​,c2​,…cn​代表小杨对武器的初始熟练度。第三行包含 m 个整数 a1​,a2​,…am​代表每场战斗后武器熟练度的变化值。输出格式输出一个整数代表 m 场战斗后小杨对 n 种武器的熟练度的最大值最大是多少。输入输出样例输入 #1复制2 2 9 9 1 -1输出 #1复制10说明/提示样例 1 解释一种最优的选择方案为第一场战斗小杨选择第一种武器第二场战斗小杨选择第二种武器。数据规模与约定子任务编号数据点占比nm120%1≤105220%≤1052360%≤105≤105对全部的测试数据保证 1≤n,m≤105−104≤ci​,ai​≤104。代码实现;#include iostream #include vector #include algorithm using namespace std; int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int n,m; cinnm; vectorint c(n); int maxc-1e9; for(int i0;in;i) { cinc[i]; maxcmax(maxc,c[i]); } long long sump0; for(int i0;im;i) { int x; cinx; if(x0) sumpx; } if(n1) { long long all0; cin.seekg(0); cin.clear(); cinnm; for(int i0;in;i) cinc[i]; for(int i0;im;i) { int x; cinx; allx; } coutc[0]all\n; } else { coutmaxcsump\n; } return 0; }