【BZOJ 2809】【APIO 2012】dispatching

本文分享了一道APIO竞赛题目的解题思路及代码实现,重点介绍了使用主席树进行区间更新和查询的过程。作者通过解决调试过程中遇到的longlong类型转换和编译器差异问题,最终成功提交并通过了题目。

昨天晚上zyf神犇问我的题,虽然我太弱参加不了APIO但也做一做吧。

用小数据拍了无数次总是查不出错来,交上去就WA,后来用国内数据测发现是主席树上区间相减的值没有用long long存,小数据真是没用啊QuQ

手残不加long long毁一生

交上去还是WA,最后发现没有把windows下的I64d改成linux下的lld==

因为这个贡献了两次Wrong Answer,,,好像第一次还爆内存了?比赛时这么手残就得滚粗了QAQ

#include<cstdio>
#include<cstring>
#include<algorithm>
#define read(x) x=getint()
using namespace std;
const int N = 100003;
int getint() {
	int k = 0, fh = 1; char c = getchar();
	for(; c < '0' || c > '9'; c = getchar())
		if (c == '-') fh = -1;
	for(; c >= '0' && c <= '9'; c = getchar())
		k = k * 10 + c - '0';
	return k * fh;
}
struct node1 {
	int b, c, l, id;
} Q[N];
struct node2 {
	int l, r, s;
	long long sc;
}T[N * 30];
int S[N], n, m, point[N], nxt[N], to[N], cnt = 0, rt = 0, L[N], R[N], H[N];
int root[N], CL[N];
void ins(int x, int y) {nxt[++cnt] = point[x]; to[cnt] = y; point[x] = cnt;}
void dfs(int x) {
	S[++cnt] = x;
	L[x] = cnt;
	for(int i = point[x]; i; i = nxt[i]) dfs(to[i]);
	R[x] = cnt;
}
bool cmp(node1 X, node1 Y) {return X.c < Y.c;}
void update(int l, int r, int &pos, int key) {
	T[++cnt] = T[pos]; pos = cnt; ++T[pos].s; T[pos].sc += Q[key].c;
	if (l == r) return;
	int mid = (l + r) >> 1;
	if (key <= mid) update(l, mid, T[pos].l, key);
	else update(mid + 1, r, T[pos].r, key);
}
long long Query(int l, int r, int x, int y, int key) {
	if (l == r) {
		if (T[y].sc - T[x].sc <= key) return T[y].s - T[x].s;
		else return key / Q[l].c;
	}
	int mid = (l + r) >> 1; long long su = T[T[y].l].sc - T[T[x].l].sc;
	if (su >= key) return Query(l, mid, T[x].l, T[y].l, key);
	else return T[T[y].l].s - T[T[x].l].s + Query(mid + 1, r, T[x].r, T[y].r, key - su);
}
int main() {
	read(n); read(m);
	for(int i = 1; i <= n; ++i)
		read(Q[i].b), read(Q[i].c), read(Q[i].l), Q[i].id = i, CL[i] = Q[i].l;
	for(int i = 1; i <= n; ++i)
		if (Q[i].b == 0) rt = i;
		else ins(Q[i].b, i);
	cnt = 0;
	dfs(rt);
	sort(Q + 1, Q + n + 1, cmp);
	for(int i = 1; i <= n; ++i)
		H[Q[i].id] = i;
	cnt = 0;
//	for(int i = 1; i <= n; ++i) printf("%d %d\n", L[i], R[i]);
//	for(int i = 1; i <= n; ++i)	printf("!! %d\n", H[i]);
//	for(int i = 1; i <= n; ++i)	printf("!! %d\n", Q[H[i]].c);
	for(int i = 1; i <= n; ++i) {
		root[i] = root[i - 1];
		update(1, n, root[i], H[S[i]]);
//		printf("HHH %d\n", S[i]);
//		printf("!!! %d\n", H[S[i]]);
	}
//	for(int i = 1; i <= n ;++i) printf("%I64d ", T[root[i]].sc); puts("");
	long long ans = 0;
	for(int i = 1; i <= n; ++i)
		ans = max(ans, CL[i] * Query(1, n, root[L[i] - 1], root[R[i]], m));
	printf("%lld\n", ans);
//	for(int i = 1; i <= n; ++i) printf("%d %d\n", L[i], R[i]);
	return 0;
}

没有删掉愚蠢的调试信息,,,

转载于:https://www.cnblogs.com/abclzr/p/5419835.html

本数据集来源于 2024 年 7 月在江西省中东部余干县、贵溪市、金溪县丘陵林地采集的千枚岩、红砂岩、花岗岩母质发育红壤关键带剖面土壤实测数据,空间覆盖 3 个县域不同岩性风化壳林地,采样点位经纬度分别为千枚岩剖面 P10(116.8316°E,28.5269°N)、红砂岩剖面 P08(117.1048°E,28.3492°N)、花岗岩剖面 P04(116.6883°E,27.9963°N);垂直空间采样深度存在差异,千枚岩与花岗岩剖面采样深度 0~600 cm,红砂岩剖面采样深度 0~450 cm,垂直分层采样分辨率为 0~50 cm 区间分 0~20 cm、20~50 cm 两层,50 cm 以下土层以 50 cm 为固定间隔分层,整套数据集共包含 36 条土壤剖面分层记录,其中 P10 千枚岩剖面 13 条、P08 红砂岩剖面 11 条、P04 花岗岩剖面 13 条。数据采集时间为 2024 年 7 月,实验室理化指标、矿物测试、酸碱滴定及统计建模工作于 2024 年 7 月 —2026 年 5 月完成,无时间序列连续监测数据,仅为单次野外剖面采样静态数据集。 数据集包含野外剖面基础信息、土壤酸碱滴定原始数据、土壤酸度指标、交换性盐基与交换性酸、土壤机械组成、有机质、黏土与原生矿物半定量 XRD 数据、无定形 / 晶形铁铝氧化物含量。全量理化指标计量单位统一规范:酸缓冲容量 pHBC 单位为 cmol・kg⁻¹・pH⁻¹,交换性酸、交换性盐基离子单位为 cmol・kg⁻¹,矿物以质量百分比(%)表示,、黏粒 / 粉粒 / 砂粒、有机质、铁铝氧化物单位均为g/kg,pH 为无量纲数值。 覆盖范围: 中位纬度: 28.2616 中位经度: 116.89654999999999 南界纬度: 27.9963 西界经度: 116.6883 北界纬度: 28.5269 东界经
【内容概要】 基于 Vite 6 与 TypeScript 5 严格模式构建的企业级前端工程化脚手架模板,开箱集成代码规范、单元测试、持续集成与容器化部署的完整链路。模板将 ESLint 9 扁平化配置、typescript-eslint 类型感知规则、Prettier 3 格式化、Vitest 2 单元测试(含 V8 覆盖率 80% 阈值)、Husky v9 + lint-staged 提交前钩子,以及 GitHub Actions 多版本 Node 矩阵流水线打通到位,另附多阶段 Dockerfile 与 nginx 静态托管配置,可在本地 pnpm install 或 docker compose up 直接启动。源码层面提供分级日志器 Logger、强类型事件总线 EventBus(基于 mitt)、Rust 风格 Result 类型、数字与字节时长格式化工具、可复用 Counter 组件等示例,并配套 32 个 Vitest 用例,演示如何在严格类型约束下编写可测试、可维护的工程化代码。 【适合人群】 1. 准备搭建中大型前端项目,需要一份可直接落地的工程化基线模板的全栈工程师; 2. 希望系统理解 Vite 构建配置、ESLint 9 扁平配置、Vitest 覆盖率门槛与 GitHub Actions 流水线如何串联的中级前端开发者; 3. 在团队中负责制定前端规范、CI 流程与 Docker 部署方案的技术负责人; 4. 学习 TypeScript 严格模式下编写类型安全工具库、组件、事件系统的实战示范的学习者。 【能学到什么】 1. Vite 6 + TypeScript 5 严格模式(strict、noUncheckedIndexedAccess、exactOptionalPropertyTypes)下的工程结构组织方式; 2. ESLint 9 Fl
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值