Plants Vs Zombies Online_vascular plant

Plants Vs Zombies Online_vascular plant24 83 2 6 63 910 10 164题解贪心+二分#include<bits/stdc++.h>using namespace std;typedef long long ll;const int N = 2e5 + 10;ll a[N],st[N]; int n,m;bool check(ll x){ memset(st,0,sizeof st); ll cnt = 0; for(int i = 1;i <= ..

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

在这里插入图片描述
在这里插入图片描述

2
4 8
3 2 6 6
3 9
10 10 1
6
4

题解
贪心+二分

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 2e5 + 10;
ll a[N],st[N];
    int n,m;
bool check(ll x){ 
   
    memset(st,0,sizeof st);
    ll cnt = 0;
    for(int i = 1;i <= n;i ++){ 
   
        if(st[i] < x){ 
   
            ll r = (x - st[i] + a[i] - 1) / a[i];
            st[i] += r * a[i],st[i + 1] += (r - 1) * a[i + 1];
            cnt += (2 * r - 1);
        }
        else{ 
   
            st[i] += a[i];
            cnt ++;
        }
        if(cnt > m)return false;
    }
    return cnt <= m;
}
int main(){ 
   
    int T;
    cin>>T;
    while(T --){ 
   
        cin>>n>>m;
        bool flag = false;
        for(int i = 1;i <= n;i ++){ 
   
            cin>>a[i];
            if(a[i] == 0)flag = true;
        }
        if(flag){ 
   
            cout<<0<<endl;
            continue;
        }
        ll l = 0,r = 1e12;
        while(l < r){ 
   
            ll mid = (l + r + 1) >> 1;
            if(check(mid))l = mid;
            else r = mid - 1;
        }
        cout<< l << endl;
    }
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168493.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月8日 上午10:00
下一篇 2022年8月8日 上午10:16


相关推荐

  • AgenticSeek – 完全本地的AI助手替代方案

    AgenticSeek – 完全本地的AI助手替代方案

    2026年3月15日
    1
  • ifndef 详解

    ifndef 详解原博文 https www cnblogs com codingmengme p 7221295 html ifndef 是 ifnotdefined 的简写 是预处理功能 宏定义 文件包含 条件编译 当中的条件编译 可以根据是否已经定义了一个变量来进行分支选择 其作用是 1 防止头文件的重复包含和编译 2 便于程序的调试和移植 下面分别举例描述 一 防止头文件的重复包含和编译下面是错误示范 headfile 1 h include

    2026年3月19日
    2
  • openclaw如何安装skills

    openclaw如何安装skills

    2026年3月13日
    2
  • JavaScript中的document.cookie的使用

    JavaScript中的document.cookie的使用 我们已经知道,在document对象中有一个cookie属性。但是Cookie又是什么?“某些Web站点在您的硬盘上用很小的文本文件存储了一些信息,这些文件就称为Cookie。”——MSIE帮助。一般来说,Cookies是CGI或类似,比HTML高级的文件、程序等创建的,但是javascript也提供了对Cookies的很全面的访问权利。  我们先要学

    2022年7月27日
    9
  • CSS中设置鼠标样式

    CSS中设置鼠标样式cursor规则是设定网页浏览时用户鼠标指针的样式,也就是鼠标的图形形状所有主流浏览器都支持cursor属性。注释:Opera9.3和Safari3不支持 url 值。注释:任何版本的InternetExplorer(包括IE8)都不支持属性值"inherit"。定义和用法cursor属性规定要显示的光标的类型(形状)。该属性定义了鼠标指针放在一个…

    2022年5月31日
    46
  • 字符串转整型c#_java字符串数组转字符串

    字符串转整型c#_java字符串数组转字符串在C++11中增加了string的字符串以及整数之间的转换函数标准增加了全局函数。std::to_stringstd::stoistd::stolstd::stoll用来将整型转换为字符串for(size_ti=0;i<14;i++){ stringfileName=”chID”+std::to_string(i)+”.hex”;}…

    2022年10月19日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号