计蒜客公告板

题目

蒜厂有一个 h×w 的矩形公告板,其中 h 是高度,w 是宽度。
现在有若干张 1×Wi 的公告, Wi 是宽度,公告只能横着放,即高度为 1 的边垂直于水平面,且不能互相有重叠,每张公告都要求尽可能的放在最上面的合法的位置上。
若可以放置,输出每块可放置的位置的行号;若不存在,输出 −1。行号由上至下分别为 1,2,…,h。
输入格式
第一行三个整数 h,w,n (1≤h,w≤10^9;1≤n≤200,000) 。
接下来 n 行,每行一个整数 Wi(1≤Wi≤109) 。
输出格式
输出n 行,一行一个整数。

分析

核心思想:线段shu,节点s[p]表示其范围行的总剩余宽度之和,

AC代码(别用cin,cout,这是个坑)

#include<iostream>
#include<cstdio>
using namespace std;

const long MAXH=200001;
int s[4*MAXH];//s[p](p表示层序遍历中树状节点的下标)表示其区间行的所有剩余宽度之和
int h,w,n,flag=0;

void buildtree(int p,int l,int r){//建树
	if(l==r){//将每个叶子节点都赋为最大宽度w
        s[p]=w;
        return;
    }
    int mid=(l+r)/2;
    buildtree(p*2,l,mid);//建立左子树
    buildtree(p*2+1,mid+1,r);//建立右子树
    s[p]=s[p*2]+s[p*2+1];//更新父亲信息
    return;
}
void modify(int p,int l,int r,int v){//填数并更新线段树
    if(l==r){//找到可以放入公共板的行
        s[p]-=v;
        flag=1;
        printf("%d\n",l);
        return;
    }
    int mid=(l+r)/2;
    if(s[p*2]>=v){//左儿子的宽度够
        modify(p*2,l,mid,v);
    }
    if(s[p*2+1]>=v&&!flag){//右儿子宽度够,且这个数还没有放入行中
        modify(p*2+1,mid+1,r,v);
    }
    s[p]=s[p*2]+s[p*2+1];
    return;
}

int main()
{
    cin>>h>>w>>n;
    buildtree(1,1,h);
    int num;
    while(n--){
        scanf("%d",&num);
        flag=0;
        if(s[1]>=num)
        	modify(1,1,h,num);
        if(!flag)
            printf("-1\n");
    }
    return 0;
}

基于开源大模型的教学实训智能体软件,帮助教师生成课前备课设、课后检测问答,提升效率与效果,提供学生全时在线练习与指导,实现教学相长。 智能教学辅助系统 这是一个智能教学辅助系统的前端项目,基于 Vue3+TypeScript 开发,使用 Ant Design Vue 作为 UI 组件库。 功能模块 用户模块 登录/注册功能,支持学生和教师角色 毛玻璃效果的登录界面 教师模块 备课与设:根据课程大纲自动设教学内容 考核内容生成:自动生成多样化考核题目及参考答案 学情数据分析:自动化检测学生答案,提供数据分析 学生模块 在线学习助手:结合教学内容解答问题 实时练习评测助手:生成随练题目并纠错 管理模块 用户管理:管理员/教师/学生等用户基本管理 课件资源管理:按学科列表管理教师备课资源 大屏概览:使用统、效率指数、学习效果等 技术栈 Vue3 TypeScript Pinia 状态管理 Ant Design Vue 组件库 Axios 请求库 ByteMD 编辑器 ECharts 图表库 Monaco 编辑器 双主题支持(专业科技风/暗黑风) 开发指南 # 安装依赖 npm install # 启动开发服务器 npm run dev # 构建生产版本 npm run build 简介 本项目旨在开发一个基于开源大模型的教学实训智能体软件,帮助教师生成课前备课设、课后检测问答,提升效率与效果,提供学生全时在线练习与指导,实现教学相长。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值