关注
int main()
{
int n, m, x, k;
cin >> n >> m >> x >> k;
vector<int> nums(n, 0);
for (int i = 0; i < n; i++)
cin >> nums[i];
int m_min = 50000;
for (auto its : nums)
m_min = min(its, m_min);
int m_max = m_min + m * k;
int l = 1;
int r = m_max;
while (l < r) {
int mid = (l + r + 1)/2;
vector<int> dp(n, 0);
int numm = 0;
bool b1 = true;
for (int i = 0; i < n; i++) {
int num = 0;
int r0 = i + x < n ? i + x : n-1;
for (int j = i - x>0 ? i - x : 0; j <= r0; j++) {
num += dp[j];
}
if (num * k + nums[i] >= mid) {
continue;
}
else {
int lest = mid - num * k - nums[i];
int num2 = lest / k;
if (lest % k != 0)
num2++;
if (num2 + numm > m) {
b1 = false;
break;
}
dp[r0] += num2;
numm += num2;
}
}
if (b1)
{
l = mid;
}
else
r = mid - 1;
}
cout << (l + r) / 2 << endl;
system("pause");
}
二分查找
查看原帖
6 2
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 什么是优秀的实习经历 #
8017次浏览 205人参与
# 担心入职之后被发现很菜怎么办 #
266064次浏览 1131人参与
# 被上班搭子“传染”了哪些习惯 #
5273次浏览 97人参与
# 投格力的你,拿到offer了吗? #
152232次浏览 813人参与
# 工作后,你落下了哪些病根 #
12918次浏览 182人参与
# 作业帮求职进展汇总 #
82642次浏览 543人参与
# 京东美团大战,你怎么看? #
157936次浏览 859人参与
# 实习简历求拷打 #
10914次浏览 142人参与
# 如果今天是你的last day,你会怎么度过? #
58870次浏览 324人参与
# 秋招被挂春招仍然能投的公司 #
6432次浏览 94人参与
# mt对你说过最有启发的一句话 #
34665次浏览 417人参与
# 为了找工作你花了哪些钱? #
74777次浏览 359人参与
# 机械人晒出你的简历 #
146401次浏览 874人参与
# 嵌入式岗知多少 #
62960次浏览 555人参与
# 摸鱼被leader发现了怎么办 #
100409次浏览 640人参与
# 考研失败就一定是坏事吗? #
200641次浏览 1369人参与
# 秋招特别不鸣谢 #
15312次浏览 175人参与
# 2023毕业生求职有问必答 #
218572次浏览 1662人参与
# 选实习,你更看重哪方面? #
13582次浏览 214人参与
# 牛客十周岁生日快乐 #
197785次浏览 1895人参与


