CCF-CSP真题《202303-5 施肥》思路+python,c++满分题解

news2024/12/25 12:38:32

想查看其他题的真题及题解的同学可以前往查看:CCF-CSP真题附题解大全


试题编号:202303-5
试题名称:施肥
时间限制:2.0s
内存限制:1.0GB
问题描述:

问题描述

春天到了,西西艾弗岛上的 n 块田地需要施肥了。n 块田地编号为 1,2,⋯,n,按照编号从小到大的顺序排成一列。

为了给田地施肥,顿顿准备了 m 辆施肥车。但是由于土地的松软程度不同,施肥车的质量不一,不一定每一辆施肥车都能给每一块田地施肥。其中,第 i 辆施肥车只能恰好从第 li 块田地开到第 ri 块田地,并给编号在 li 与 ri 之间的田地(包含 li 和 ri)都施一遍肥。其中 1≤li<ri≤n。

顿顿希望制定一个施肥的计划。首先,他将选定二元组 (L,R)(1≤L<R≤n),并选择给编号在 L,R 之间(包含 L,R)的田地施肥。接着,他会从使用这 m 辆施肥车中的一部分(或全部)对田地施肥。他想要保证:编号在 L 和 R 之内的田地至少被某一辆施肥车施了一次肥,且编号范围外的田地都没有被施过肥。

现在,他想知道,他能够选择多少种不同的二元组 (L,R) 作为施肥范围,使得可以选出一部分(或全部)施肥车,完成他的目标。

输入格式

从标准输入读入数据。

第一行输入两个正整数 n,m,表示田地的块数和 施肥车的辆数。数据保证 2≤n≤2⋅105,1≤m≤2⋅105。

接下来 m 行,第 i 行输入两个正整数 li,ri,表示第 i 辆施肥车的施肥范围从第 li 块田地到第 ri 块田地。数据保证 1≤li<ri≤n。

输出格式

输出到标准输出。

输出一个正整数,表示顿顿能够选择多少种不同的二元组 (L,R) 作为施肥范围,使得他可以选出一部分(或全部)施肥车,完成他的目标。

样例输入1

4 3
1 2
3 4
2 3

样例输出1

6

样例解释

在这组样例中,顿顿可以选择 6 种不同的二元组 (L,R)。

第一种:选择 (L,R)=(1,2),并只选取第 1 个施肥车施肥。

第二种:选择 (L,R)=(3,4),并只选取第 2 个施肥车施肥。

第三种:选择 (L,R)=(2,3),并只选取第 3 个施肥车施肥。

第四种:选择 (L,R)=(1,4),并选取第 1 个和第 2 个施肥车施肥。

第五种:选择 (L,R)=(1,3),并选取第 1 个和第 3 个施肥车施肥。

第六种:选择 (L,R)=(2,4),并选取第 2 个和第 3 个施肥车施肥。

样例2

见题目目录下的 2.in 与 2.ans

这个样例满足 n,m≤18。

样例3

见题目目录下的 3.in 与 3.ans

这个样例满足 n,m≤50。

样例4

见题目目录下的 4.in 与 4.ans

这个样例满足 n,m≤400。

样例5

见题目目录下的 5.in 与 5.ans

这个样例满足 n,m≤3000。

样例6

见题目目录下的 6.in 与 6.ans

这个样例满足特殊性质 A。

样例7

见题目目录下的 7.in 与 7.ans

这个样例满足 n,m≤200000。

子任务

测试点编号n≤m≤特殊性质
11818
21818
31818
45050
55050
6400400
7400400
830003000
930003000
1030003000
1130003000
1230003000
13200000200000A
14200000200000A
15200000200000A
16200000200000
17200000200000
18200000200000
19200000200000
20200000200000

特殊性质 A:保证任意两个施肥车的施肥范围不存在相互包含的关系,也就是说,对任意 1≤i<j≤m,li<lj,ri<rj 或 li>lj,ri>rj。

真题来源:施肥

 感兴趣的同学可以如此编码进去进行练习提交

思路来源:CCF-CSP认证 202303 500分题解

c++满分题解:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define SZ(x) (int)x.size()
#define fi first
#define se second
const int N=2e5+10,INF=0x3f3f3f3f;
int n,m,l,r,a[N],b[N];
vector<int>L[N],R[N];
ll ans;
struct segtree{
	int n;
	struct node{int l,r,c,mn,mx;}e[N<<2];
	#define l(p) e[p].l
	#define r(p) e[p].r
	#define c(p) e[p].c
	#define mn(p) e[p].mn
	#define mx(p) e[p].mx
	void up(int p){
		mn(p)=min(mn(p<<1),mn(p<<1|1));
		mx(p)=max(mx(p<<1),mx(p<<1|1));
	}
	void bld(int p,int l,int r){
		l(p)=l;r(p)=r;c(p)=0;
		if(l==r){mn(p)=INF;mx(p)=-INF;return;}
		int mid=l+r>>1;
		bld(p<<1,l,mid);bld(p<<1|1,mid+1,r);
		up(p);
	}
	void init(int _n){n=_n;bld(1,1,n);}
	void chg(int p,int x,int v){
		if(l(p)==r(p)){mn(p)=min(mn(p),v);mx(p)=max(mx(p),v);return;}
		int mid=l(p)+r(p)>>1;
		psd(p);
		chg(p<<1|(x>mid),x,v);
		up(p);
	}
	void psd(int p){
		if(c(p)){
			mn(p<<1)=INF;
			mx(p<<1)=-INF;
			c(p<<1)=c(p);
			mn(p<<1|1)=INF;
			mx(p<<1|1)=-INF;
			c(p<<1|1)=c(p);
			c(p)=0; 
		}
	}
	void del(int p,int ql,int qr){
		if(ql<=l(p)&&r(p)<=qr){
			mn(p)=INF;
			mx(p)=-INF;
			c(p)=1;
			return;
		}
		psd(p);
		int mid=l(p)+r(p)>>1;
		if(ql<=mid)del(p<<1,ql,qr);
		if(qr>mid)del(p<<1|1,ql,qr);
		up(p);
	}
	int amn(int p,int ql,int qr){
		if(ql<=l(p)&&r(p)<=qr)return mn(p);
		int mid=l(p)+r(p)>>1,res=INF;
		psd(p);
		if(ql<=mid)res=min(res,amn(p<<1,ql,qr));
		if(qr>mid)res=min(res,amn(p<<1|1,ql,qr));
		return res;
	}
	int amx(int p,int ql,int qr){
		if(ql<=l(p)&&r(p)<=qr)return mx(p);
		int mid=l(p)+r(p)>>1,res=-INF;
		psd(p);
		if(ql<=mid)res=max(res,amx(p<<1,ql,qr));
		if(qr>mid)res=max(res,amx(p<<1|1,ql,qr));
		return res;
	}
}seg,lseg,rseg;
struct BitPre{
	int n,tr[N];
	void init(int _n){
		n=_n;
		memset(tr,0,(n+1)*sizeof(*tr));
	}
	void add(int x,int v){
		for(int i=x;i<=n;i+=i&-i)
		tr[i]+=v;
	}
	int ask(int x){
		if(x<0)return 0;
		int ans=0; 
		for(int i=x;i;i-=i&-i)
		ans+=tr[i];
		return ans;
	}
}tr;
bool ok(int x){
	return x!=INF && x!=-INF;
}
bool in(int x,int l,int r){
	return l<=x && x<=r;
}
void cdq(int l,int r){
	if(l==r)return;
	int mid=(l+r)/2;
	cdq(l,mid);cdq(mid+1,r);
	for(int i=mid;i>=l;--i){
		a[i]=-INF;b[i]=INF;
		for(auto &v:L[i]){
			if(v>r)continue;
			if(v<=mid)a[i]=max(a[i],v);
			else b[i]=min(b[i],v);//有无需本侧的情况
			if(v>=mid)rseg.chg(1,v,i);
		}
		if(ok(a[i])){
			a[i]=max(a[i],seg.amx(1,i,min(mid,a[i]+1)));
			seg.chg(1,i,a[i]);
		}
	}
	for(int i=mid+1;i<=r;++i){
		a[i]=INF;b[i]=-INF;
		for(auto &v:R[i]){
			if(v<l)continue;
			if(v>=mid+1)a[i]=min(a[i],v);
			else b[i]=max(b[i],v);
			if(v<=mid+1)lseg.chg(1,v,i);
		}
		if(ok(a[i])){
			a[i]=min(a[i],seg.amn(1,max(mid+1,a[i]-1),i));
			seg.chg(1,i,a[i]);
		}
	}
	vector<array<int,3>>all;
	for(int i=mid;i>=l;--i){
		if(ok(a[i])){ // [i,a[i]+1]
			int v=lseg.amn(1,i,a[i]+1);
			if(in(v,mid+1,r)){
				b[i]=min(b[i],v);
			}
		}
		if(in(b[i],mid+1,r))all.push_back({i,0,b[i]});
	}
	for(int i=mid+1;i<=r;++i){
		if(ok(a[i])){ // [a[i]-1,i]
			int v=rseg.amx(1,a[i]-1,i);
			if(in(v,l,mid)){
				b[i]=max(b[i],v);
			}
		}
		if(in(b[i],l,mid))all.push_back({b[i],1,i});
	}
	sort(all.begin(),all.end());
	for(auto &w:all){
		int op=w[1],ub=w[2];
		if(op==0)tr.add(ub,1);
		else ans+=tr.ask(ub);//左[l,a[l]]右[a[r],r],满足l<=a[r]<=a[l]+1且a[r]-1<=a[l]<=r,a[l]<=mid<mid+1<=a[r]显然成立
	}
	seg.del(1,l,r);lseg.del(1,l,r);rseg.del(1,l,r);
	for(auto &w:all){
		int op=w[1],ub=w[2];
		if(op==0)tr.add(ub,-1);
	}
}
int main(){
	scanf("%d%d",&n,&m);
	seg.init(n);lseg.init(n);rseg.init(n);tr.init(n);
	for(int i=1;i<=m;++i){
		scanf("%d%d",&l,&r);//重复无所谓
		L[l].push_back(r);
		R[r].push_back(l);
	}
	cdq(1,n);
	printf("%lld\n",ans);
	return 0;
}

运行结果:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/726026.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Mysql之进阶宝典系列-视图

Mysql之进阶宝典系列-视图 一、视图是什么(what) 视图本质上是一个虚表&#xff0c;在数据库中不实际存在&#xff0c;它的所有数据来源于查询中所使用的表的数据&#xff0c;而且是在视图调用过程中动态生成的。视图只保存了SQL查询的逻辑&#xff0c;不保存SQL查询的结果。 …

HarmonyOS学习路之开发篇—数据管理(关系型数据库)

关系型数据库概述 关系型数据库&#xff08;Relational Database&#xff0c;RDB&#xff09;是一种基于关系模型来管理数据的数据库。HarmonyOS关系型数据库基于SQLite组件提供了一套完整的对本地数据库进行管理的机制&#xff0c;对外提供了一系列的增、删、改、查等接口&am…

深度学习-GPU多卡并行训练总结

1.为什么要使用多GPU并行训练 简单来说&#xff0c;有两种原因&#xff1a;第一种是模型在一块GPU上放不下&#xff0c;两块或多块GPU上就能运行完整的模型&#xff08;如早期的AlexNet&#xff09;。第二种是多块GPU并行计算可以达到加速训练的效果。想要成为“炼丹大师“&…

【原生HTML+SpringBoot】电子病历编辑器源码

一、简介 本系统主要面向医院医生、护士&#xff0c;提供对住院病人的电子病历书写、保存、修改、打印等功能。本系统基于云端SaaS服务方式&#xff0c;通过浏览器方式访问和使用系统功能&#xff0c;提供电子病历在线制作、管理和使用的一体化电子病历解决方案&#x…

常见面试题之JVM组成

1. JVM由那些部分组成&#xff0c;运行流程是什么&#xff1f; JVM是什么 Java Virtual Machine Java程序的运行环境&#xff08;java二进制字节码的运行环境&#xff09; 好处&#xff1a; 一次编写&#xff0c;到处运行 自动内存管理&#xff0c;垃圾回收机制 JVM由哪些…

sqldeveloper 连接 MySQL

sqldeveloper 连接 MySQL 工作中使用 Oracle 用户的小伙伴&#xff0c;sqldeveloper 是常用的开发和运维工具之一 工作中如果连接MySQL需要安装额外的客户端工具 不但学习成本高而且维护也较为麻烦 能不能使用 sqldeveloper 可以同时管理Oracle和MySQL两种甚至更多种数据库 成为…

基于Javaweb实现ATM机系统开发实战(一)基础配置和搭建

一、环境介绍 JDK:JDK1.8 IDEA:2020 MYSQL :MYSQL5.7 Navcat :mysql的客户端工具 Tomcat:tomcat5.7 二、项目简介 本项目主要实现一个模拟ATM机存款、取款、转账功能的一个系统&#xff0c;可以查看打印交易明细&#xff0c;后台用户可以管理用户账户卡信息。本系统主要是针对计…

Java易忘知识点

Java八大基本类型 整数类型&#xff1a;byte&#xff0c;1字节&#xff0c;8位&#xff0c;最大存储数据量是255&#xff0c;存放的数据范围是-128~127之间。整数类型&#xff1a;short&#xff0c;2字节&#xff0c;16位&#xff0c;最大数据存储量是65536&#xff0c;数据范…

centos下./configure报错:Permission denied

./configure 文章目录 ./configure报错解决方案使用chmod给./configure赋予x权限sftp给configure文件赋予x权限 ./configure报错 -bash: ./configure: Permission denied解决方案 使用chmod给./configure赋予x权限 sudo chmod x ./configuresftp给configure文件赋予x权限

推荐一个基于Java 的在线网盘开源程序

目录 一、软件简介 二、功能列表 文件列表 画廊模式 视频预览 文本预览 音频预览 PDF 预览 Office 预览 3d 文件预览 生成直链 页面设置 后台设置-登录 后台设置-存储源列表 后台设置-存储源权限控制 后台设置-添加存储源(本地存储) 后台设置-添加存储源 后…

Spring Boot中的请求参数绑定及使用

Spring Boot中的请求参数绑定及使用 在Web应用程序中&#xff0c;请求参数绑定是非常重要的操作。Spring Boot框架使得请求参数绑定变得非常简单&#xff0c;通过使用注解和预定义的类可以轻松地实现此操作。本文将介绍Spring Boot中的请求参数绑定及其使用。 请求参数绑定 在…

第十章:C语言数据结构与算法初阶之链式二叉树

系列文章目录 文章目录 系列文章目录前言一、链式二叉树的定义二、链式二叉树的实现三、链式二叉树的遍历1、前序遍历/先根遍历2、中序遍历/中根遍历3、后序遍历/后根遍历4、层序遍历5、前/中/后序遍历的关系 四、节点个数以及高度等1. 二叉树节点的个数2. 二叉树叶子节点个数3…

Java面试知识点复习​_kaic

一、后端基础 1.Java基础、集合、线程、异常&#xff08;自定义异常&#xff09;流 2.mysql、redis、mongodb(为什么使用) 3.ssm、springboot、springcloud、mybatis-plus 1.接口和抽象类的区别 二、前端基础 1.事件 三、实习和项目 1.博客项目的日志配置&#xff08;切面&a…

flutter tabBar 的属性及自定义实现

flutter tabBar 的属性及自定义实现 前言一、TabBar是什么&#xff1f;二、TabBar 自定义三、 Tab 自定义总结 前言 在Flutter中&#xff0c;TabBar的indicatorPadding属性用于设置指示器的内边距&#xff0c;而不是用于调整指示器和文字之间的间距。要调整TabBar中指示器和文字…

Field ‘非主键_id‘ doesn‘t have a default value

参考文章 Field ‘非主键_id‘ doesn‘t have a default value 的sql报错有两种情况 1.如果id是主键的话,一般是主键没有添加自增导致的错误 2.如果报错的是非主键id 那么是数据库设置错误 前端请求参数根本没有传入business_id 但是数据库报错 解决方法 把数据库数据限制n…

python 第九章 常用操作

系列文章目录 第一章 初识python 第二章 变量 第三章 基础语句 第四章 字符串str 第五章 列表list [] 第六章 元组tuple ( ) 第七章 字典dict {} 第八章 集合set {} 文章目录 系列文章目录9.1公共操作运算符 合并* 复制判断数据是否存在 公共方法len()delmax()min()rangeenume…

css实现文档目录(中间分割线宽度不定)

css实现文档目录&#xff08;中间分割线宽度不定&#xff09; 先上图片看效果 布局 数据 css样式 其实挺简单的&#xff0c;flex直接搞定

十六、centos7 下给python3创建虚拟环境

十五、centos7 下给python3创建虚拟环境 1.先说下为什么要创建虚拟环境 python3安装完成后&#xff0c;安装第三方库 pip3 install requests -i https://pypi.doubanio.com/simple提示如下让使用虚拟环境&#xff0c;不使用&#xff0c;即便是安装&#xff0c;也不能使用已经…

长连接和短链接详解

长连接和短链接详解 日常工作和生活中接触到的软件系统大多数情况下是由多个进程共同协作进行的&#xff0c;所以&#xff0c;了解进程之间如何进行高效的通信至关重要。 进程之间的通信有不少方式包括管道&#xff08;包括无名管道和命名管道&#xff09;、消息队列、信号量、…

Vue3在外部js文件获取Vue实例对象中的方法

刚开始想用getCurrentInstance 获取 发现这玩意只能写在setUp里面 然后百度发现在外部js文件只能先引入main.js在使用&#xff0c;这里注意要先将app实例导出 然后在外部js引用 就能获取到实例对象了 这点跟Vue2还是有很大区别