poj3667 hotel

这题目的解决方案关键是怎样制造连续的区域来判断是否符合要求。 你查找最大的区域时, 可以分为三个部分, 一个是左子树的最大连续区域, 一个是右子树最大区域, 一个 是左子树从右向左最大的连续区域加上右子树从左向右的最大区域

 
 
View Code
#include<stdio.h>
#include<string.h>
#include<math.h>
#define maxn 200008

struct node
{
int lval, rval, val;
int left, right;
int count;

void init(int x)
{
lval = rval = val = x * count;
}
}map[maxn];

inline int max(int x, int y)
{
return x > y? x:y;
}

void build(int left, int right, int side)
{
map[side].left = left;
map[side].right = right;
map[side].count = right - left + 1;
map[side].init(1);

if (left == right)
{
return;
}

int mid = (left + right) >> 1;
build(left, mid, side << 1);
build(mid + 1, right, side << 1 | 1);
return;
}

void update(int left, int right, int flag, int side)
{
int lchild, rchild;
lchild = side << 1;
rchild = side << 1 | 1;

if (map[side].left > right || map[side].right < left)
{
return;
}
if (left <= map[side].left && right >= map[side].right)
{
map[side].init(flag);
return;
}
if (map[side].val == map[side].count )
{
if (flag == 1)
{
return;
}
else
{
map[lchild].init(1);
map[rchild].init(1);
}
}
if (map[side].val == 0)
{
map[lchild].init(0);
map[rchild].init(0);
}
int mid = (map[side].left + map[side].right) >> 1;
if (mid >= right)
{
update(left, right, flag, lchild);
}
else if (left > mid )
{
update(left, right, flag, rchild);
}
else
{
update(left, mid, flag, lchild);
update(mid + 1, right, flag, rchild);
}

// left
map[side].lval = map[rchild].lval + (map[rchild].val == map[rchild].count ? map[lchild].lval:0);

// right
map[side].rval = map[lchild].rval + (map[lchild].val == map[lchild].count? map[rchild].rval:0);

//current
map[side].val = max(map[lchild].lval+map[rchild].rval, max(map[lchild].val, map[rchild].val));

return ;
}

int find(int val, int side)
{
if (map[side].val < val)
{
return 0;
}

if (map[side].val == map[side].count)
{
return map[side].left;
}

if (map[side].rval >= val)
{
return map[side].left;
}

if (map[side << 1].val >= val)
{
return find(val, side << 1);
}
if (map[side << 1].lval + map[side << 1 | 1].rval >= val)
{
return map[side << 1].right - map[side << 1].lval + 1;
}
return find(val, side << 1 | 1);
}

void print(int m)
{
int choice, x, y;

for (int i = 0; i < m; i ++)
{
scanf("%d", &choice);
if (choice == 1)
{
scanf("%d", &x);
choice = find(x, 1);
printf("%d\n", choice);
if (choice > 0)
{
update(choice, choice + x - 1, 0, 1);
}
}
else
{
scanf("%d%d", &x, &y);
update(x, x + y - 1, 1, 1);
}
}
return ;
}

int main()
{
int n, m;

scanf("%d%d", &n, &m);
build(1, n, 1);
print(m);

return 0;
}

  

转载于:https://www.cnblogs.com/yuecxl/archive/2012/03/26/2418198.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、引言 随着全球气候变化和城市化进程的加快,洪水灾害的频率和强度呈上升趋势,对人类社会和经济发展构成了严重威胁。因此,建设一套高效、准确的洪水预报与防洪形势分析系统,对于提升洪水灾害的预警能力、减轻灾害损失具有重要意义。本文旨在全面总结洪水预报与防洪形势分析系统的设计背景、目标、需求、总体设计、子系统详细设计等方面的内容,为系统的后续开发、实施和应用提供理论支撑和实践指导。 二、建设背景 洪水灾害作为一种常见的自然灾害,其发生往往伴随着巨大的经济损失和人员伤亡。为了有效应对洪水灾害,提高预警和应对能力,各国政府和相关机构纷纷投入大量资源,开展洪水预报和防洪形势分析的研究和实践。在这样的背景下,本项目的建设显得尤为重要和紧迫。通过集成先进的信息技术、水文学、气象学等多学科知识,构建一套集洪水预报、防洪形势分析、专家交互、会商决策于一体的综合性系统,旨在实现对洪水灾害的全面、精准、高效监测和预警,为洪水灾害的应对提供科学依据和技术支持。 三、项目概述 3.1 项目背景 本项目基于上述建设背景,旨在解决洪水灾害预警和应对中存在的问题和挑战。通过建设一套综合性的洪水预报与防洪形势分析系统,实现对洪水灾害的实时监测、预警、分析和决策支持,提高洪水灾害的应对能力和效率。 3.2 项目目标 本项目的核心目标包括: 实现洪水灾害的实时监测和预警,提高预警的准确性和时效性; 提供全面的防洪形势分析功能,为决策支持提供科学依据; 支持专家交互和会商决策,提高决策的科学性和有效性; 构建开放、可扩展的系统架构,支持后续的功能扩展和升级。 3.3 需求概述 为满足项目目标,系统需要满足以下需求: 实时数据采集和处理能力,确保数据的准确性和时效性; 强大的洪水预报和防洪形势分析功能,支持多种预报模型和分析方法; 友好的用户界面和交互体验,方便用户操作和使用; 高效的数据存储和管理能力,支持大规模数据的存储和查询; 可靠的系统性能和稳定性,确保系统的持续运行和可用性。 四、系统总体设计 4.1 基本设计理念 系统总体设计遵循以下基本理念: 以用户需求为导向,注重系统的实用性和易用性; 采用先进的信息技术和水文学、气象学等多学科知识,确保系统的先进性和准确性; 构建开放、可扩展的系统架构,支持后续的功能扩展和升级; 注重系统的稳定性和安全性,确保系统的持续运行和数据安全。 4.2 软件总体结构 系统采用模块化设计,包括数据采集与处理、洪水预报、防洪形势分析、专家交互、会商决策等多个模块。各模块之间通过标准化的接口进行通信和数据交换,实现系统的集成和协同工作。 4.3 系统接口设计 系统接口设计包括外部接口和内部接口两部分。外部接口负责与外部数据源进行通信和数据交换;内部接口负责各模块之间的通信和数据交换。通过标准化的接口设计,实现系统的灵活性和可扩展性。 4.4 系统整体应用模式 系统采用B/S架构,用户通过浏览器访问系统界面,实现远程访问和操作。系统支持多用户并发访问和操作,满足大规模用户的使用需求。 4.5 子系统划分 系统划分为多个子系统,包括应用支撑平台、预报模型建模子系统、洪水预报子系统、专家交互子系统、水库调洪计算子系统、中长期预报子系统、防洪形势分析子系统和会商子系统等。各子系统之间相对独立又相互关联,共同构成完整的洪水预报与防洪形势分析系统。 五、子系统详细设计 5.1 应用支撑平台 应用支撑平台是系统的基础和核心,负责提供用户管理、权限控制、日志管理、数据备份与恢复等基础功能。通过用户与权限设计,实现对用户身份和访问权限的严格控制和管理,确保系统的安全性和稳定性。 5.2 预报模型建模子系统 预报模型建模子系统负责构建和维护洪水预报模型。通过集成多种预报模型和分析方法,实现对洪水灾害的精准预报和分析。子系统包括模型库管理、模型参数设置、模型训练与验证等功能模块。 5.3 洪水预报子系统 洪水预报子系统是系统的核心功能之一,负责根据实时数据和预报模型,对洪水灾害进行实时监测和预警。子系统包括数据采集与处理、洪水预报计算、预警信息发布等功能模块。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值