`
huyifan951124
  • 浏览: 83495 次
社区版块
存档分类
最新评论

2016北京网赛Countires

 
阅读更多

题目大意:两个城市A,B分别有两个护盾,现已知B护盾开启的时间和持续的时间,两个城市互相射击炮弹,如果打到的城市有护盾则反弹给另一个。现在问你要使得A城市最小受到的伤害是多少?

算法思路:我们只需要算出每颗炮弹给A造成的伤害区间,将其转化为区间交问题,即可。

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
#define MAXN 50050
typedef long long LL;
LL ta,tb,stb,st,ct,dam;
int na,nb;

typedef struct Shield
{
    LL l,r;
    LL dam;
};
Shield s[MAXN];
bool cmp(Shield s1,Shield s2)
{
    return s1.r<s2.r;
}
LL k[MAXN],f[MAXN];

void add(int w,LL value)
{
    for(;w<=MAXN;w+=w&-w)
        f[w]+=value;
}
LL getSum(int w)
{
    LL value=0;
   for(;w;w-=w&-w)
        value+=f[w];
    return value;
}
int main()
{
    LL lb,rb,la,ra,sum,MAX;
    int ssnum,ssnum2;
    while(scanf("%lld%lld",&ta,&tb)!=EOF)
    {

        sum=0;
         ssnum=0,ssnum2=0;

        scanf("%lld",&stb);


         lb=stb,rb=stb+tb;

        scanf("%d%d",&na,&nb);
        //a炮弹
        for(int i=1;i<=na;i++)
        {

            scanf("%lld%lld%lld",&st,&ct,&dam);
            if (st+ct<lb||st+ct>rb) continue ;
            else
            {
                ssnum++;
                s[ssnum].l=st+2*ct;
                s[ssnum].dam=dam;
                sum+=dam;
                s[ssnum].r=st+2*ct+(rb-st-ct)/(2*ct)*(2*ct);

            }
        }

        //b炮弹
        for(int i=1;i<=nb;i++)
        {

            scanf("%lld%lld%lld",&st,&ct,&dam);
            ssnum++;
            s[ssnum].l=st+ct;
            s[ssnum].dam=dam;
            sum+=dam;
            if (rb<st+2*ct||st+2*ct<lb)
                s[ssnum].r=s[ssnum].l;
            else s[ssnum].r=st+3*ct+(rb-st-2*ct)/(2*ct)*(2*ct);

        }


        for(int i=1;i<=ssnum;i++)
        {
            k[++ssnum2]=s[i].l;
            k[++ssnum2]=s[i].r;
            k[++ssnum2]=s[i].r-ta;
        }
        sort(s+1,s+ssnum+1,cmp);
        sort(k+1,k+ssnum2+1);
        int K=unique(k+1,k+ssnum2+1)-(k+1);//去重
        memset(f,0,sizeof(f));
        MAX=0;

        for(int i=1;i<=ssnum;i++)
        {
            int k1=lower_bound(k+1,k+K+1,s[i].l)-k;
            int k2=lower_bound(k+1,k+K+1,s[i].r)-k;
            int k3=lower_bound(k+1,k+K+1,s[i].r-ta)-k;
            add(k1,s[i].dam);

            MAX=max(MAX,getSum(k2)-getSum(k3-1));
        }

        printf("%lld\n",sum-MAX);

    }


    return 0;
}

 

分享到:
评论

相关推荐

    countires-API:一个从API获取国家信息的网站

    Countires网站 通过输入国家名称获取国家标志,本地名称和国际名称的网站 目录 基本信息 这个项目是简单的网站,其中包含: 带有简单验证的登录页面,用户名和密码only 5 characters 搜索输入已验证的主页, only-...

    project-milestone-js:使用API​​的国家/地区数据

    Countires Web App可在台式机,平板电脑和移动设备上使用。 该应用程序可用于多种目的,包括提供教育以支持项目事实或供潜在旅行者研究目的地。 该应用程序包含一个简单的下拉框,用户可以在其中选择所需的国家/...

    db-regions:该存储库具有易于使用和采用的基本区域数据,并欢迎在我和您的下一个项目中使用的任何贡献

    注意:您必须先添加countires 表,因为所有其他表都依赖于它,否则您应该更改SQL 文件以删除依赖项。 国家 如果你想添加countires,请先添加{db}/countries/countries.sql文件。 然后你也可以添加 i18n 来获取不同...

    在开放式创新平台中使用手机:一种特别适合发展中国家手机行业的新商业模式-研究论文

    本文的目的是为开放式创新平台提出一种新的商业模式,该平台特别适合发展中国家的移动电话部门。 在许多情况下,开放式创新已被证明是进行创新的一种优越手段,但是迄今为止,在发展中国家,开放式创新仅得到了很少...

    第11讲:深入理解指针(1).pdf

    第11讲:深入理解指针(1)

    springboot整合 freemarker方法

    springboot整合 freemarker方法

    第14讲:深入理解指针(4).pdf

    第14讲:深入理解指针(4)

    同行者4.1.2语音助手

    《同行者4.1.2语音助手:车机版安装详解》 在现代科技日新月异的时代,智能车载设备已经成为了汽车生活的重要组成部分。"同行者4.1.2"便是这样一款专为车机设计的语音助手,旨在提供更为便捷、安全的驾驶体验。该版本针对掌讯全系列设备进行了兼容优化,让车主能够轻松实现语音控制,减少驾驶过程中的手动操作,提升行车安全性。 我们来了解下"同行者4.1.2"的核心功能。这款语音助手集成了智能语音识别技术,用户可以通过简单的语音指令完成导航、音乐播放、电话拨打等一系列操作,有效避免了因操作手机或车机带来的分心。此外,其强大的语义理解和自学习能力,使得它能逐步适应用户的口音和习惯,提供更个性化的服务。 在安装过程中,用户需要注意的是,"同行者4.1.2"包含了四个核心组件,分别是: 1. TXZCore.apk:这是同行者语音助手的基础框架,包含了语音识别和处理的核心算法,是整个应用运行的基础。 2. com.txznet.comm.base.BaseApplication.apk:这个文件可能包含了应用的公共模块和基础服务,为其他组件提供支持。 3. TXZsetting.apk:这

    市场拓展主管绩效考核表.xls

    市场拓展主管绩效考核表

    “线上购车3D全方位体验:汽车模型展示与个性化定制功能”,three.js案例- 线上购车3d展示(源码) 包含内容:1.汽车模型展示;2.汽车肤;3.轮毂部件更;4.开关车门动画;5.汽车尺寸测量

    “线上购车3D全方位体验:汽车模型展示与个性化定制功能”,three.js案例- 线上购车3d展示(源码) 包含内容:1.汽车模型展示;2.汽车肤;3.轮毂部件更;4.开关车门动画;5.汽车尺寸测量;6.自动驾驶;7.镜面倒影;8.hdr运用;9.移动端适配; 本为html+css+three.js源码 ,核心关键词:three.js案例; 线上购车3D展示; 汽车模型展示; 汽车换肤; 轮毂部件更换; 开关车门动画; 汽车尺寸测量; 自动驾驶; 镜面倒影; HDR运用; 移动端适配; HTML+CSS+three.js源码。,"Three.js源码:线上购车3D展示案例,含汽车模型、换肤、轮毂更换等九大功能"

    (数据权威)中国城市_县域统计面板数据二合一

    数据名称:2000-2022年各县市区主要社会经济发展指标面板数据 数据类型:dta格式 数据来源:中国县域统计

    120页-环卫车项目初步方案.pdf

    一、智慧环卫管理平台的建设背景与目标 智慧环卫管理平台的建设源于对环卫管理全面升级的需求。当前,城管局已拥有139辆配备车载GPS系统、摄像头和油耗传感器的环卫车辆,但环卫人员尚未配备智能移动终端,公厕也缺乏信息化系统和智能终端设备。为了提升环卫作业效率、实现精细化管理并节省开支,智慧环卫管理平台应运而生。该平台旨在通过信息化技术和软硬件设备,如车载智能终端和环卫手机App,实时了解环卫人员、车辆的工作状态、信息和历史记录,使环卫作业管理透明化、精细化。同时,平台还期望通过数据模型搭建和数据研读,实现更合理的环卫动态资源配置,为环卫工作的科学、健康、持续发展提供决策支持。 二、智慧环卫管理平台的建设内容与功能 智慧环卫管理平台的建设内容包括运行机制体制建设、业务流程设计、智慧公厕系统建设、网络建设、主机和储存平台需求、平台运维管理体系、硬件标准规范体系以及考核评价体系等多个方面。其中,智慧公厕系统建设尤为关键,它能实时监控公厕运行状态,保障公厕的清洁和正常运行。平台建设还充分利用了现有的电子政务网络资源,并考虑了有线和无线网络的需求。在功能上,平台通过普查、整合等手段全面收集环卫车辆、企业、人员、设施、设备等数据,建立智慧环卫基础数据库。利用智能传感、卫星定位等技术实现环卫作业的在线监管和远程监控,实现对道路、公共场所等的作业状况和卫生状况的全面监管。此外,平台还建立了环卫作业网格化管理责任机制,实现从作业过程到结果的全面监管,科学评价区域、部门、单位和人员的作业效果。 三、智慧环卫管理平台的效益与风险规避 智慧环卫管理平台的建设将带来显著的环境、经济和管理效益。环境方面,它将有力推进环境卫生监管服务工作,改善环境卫生状况,为人民群众创造更加清洁、卫生的工作和生活环境。经济方面,通过智慧化监管,大大降低了传统管理手段的成本,提高了监管的准确性和效率。管理方面,平台能够追踪溯源市民反映的问题,如公厕异味、渣土车辆抛洒等,并找到相应的责任单位进行处置,防止类似事件再次发生。同时,平台还拥有强大的预警机制功能,能够在很多环卫问题尚未出现前进行处置。然而,平台建设也面临一定的风险,如部门协调、配合问题,建设单位选择风险以及不可预测的自然灾害等。为了规避这些风险,需要加强领导、统一思想,选择优秀的系统集成商承接项目建设,并做好计算机和应用系统的培训工作。同时,也要注意标准制定工作和相关法律法规的制定工作,以保证系统建设完成后能够真正为环卫管理工作带来便利。

    36 -企业管理主管绩效考核表1.xlsx

    36 -企业管理主管绩效考核表1

    1.1 -1.4 工程代码

    1.1 -1.4 工程代码

    USDT合约,USDT智能合约

    USDT合约,USDT智能合约

    基于姿态估计三维人脸形状重建.pdf

    基于姿态估计三维人脸形状重建.pdf

    一般员工绩效考核表模板(通用版) (2).xls

    一般员工绩效考核表模板(通用版) (2)

    全国295个地级市2011-2022互联网宽带接入用户数互联网普及率(数据权威)

    全国各省295地级市互联网普及率、互联网用户数、每百人互联网宽带用户(2011-2022年) 数据年份:2011-2022年(2022存在部分缺失) 数据范围:全国各省295个地级市 数据来源:地方统计局

    (数据权威)碳排放、碳中和、碳交易、碳金融、碳计算、碳建模资料

    一、各省、分行业CO2排放、283个地级市碳排放及计算过程 2.分行业二氧化碳排放量 在这里插入图片描述 3、280多个地级市碳排放及计算过程 二、碳中和文献、最新政策、碳金融数据+数学建模 1.二氧化碳减排规划,碳金融数据收集及数学建模 2.碳中和政策和下载量最高的碳中和论文 三、碳排放+碳市场+碳交易+碳中和+碳排放核算Excel自动计算表 全行业碳排放核算Excel自动计算表 四、碳交易数据 五、主要能源碳排放计算参数

    第20讲:自定义类型:结构体.pdf

    第20讲:自定义类型:结构体

Global site tag (gtag.js) - Google Analytics