csp-s模拟测试42「世界线·时间机器·密码」
$t3$不会
世界线
题解
题目让求的就是每个点能到点的数量$-$出度
设每个点能到的点为$f[x]$
则$f[x]=x \sum\limits_{y}^{y\in son[x]} U f[y]$
用$bitset$优化一下即可,但单纯这样会炸内存,随意$yy$一下,时间换空间,像平衡树一样开个垃圾桶都行
代码
#include<bits/stdc++.h>
using namespace std;
#define ll int
#define A 60001
ll dl[A],ans[A],head[A*5],nxt[A*5],ver[A*5],out[A],in[A];
ll n,m,tot,sbzzn=0;
bitset<5005> bit[A];
void add(ll x,ll y){
nxt[++tot]=head[x],head[x]=tot,ver[tot]=y;
}
void top(){
deque<ll> q;
for(ll i=1;i<=n;i++)
if(in[i]==0) q.push_back(i);
while(!q.empty()){
ll top_now=q.front();
// printf("dl[0]=%d top_now=%d\n",dl[0],top_now);
dl[++dl[0]]=top_now;
q.pop_front();
for(ll i=head[top_now];i;i=nxt[i]){
ll y=ver[i];
// printf("top_now=%d y=%d in[y]=%d\n",top_now,y,in[y]);
in[y]--;
if(in[y]==0) q.push_back(y);
}
}
}
void count(){
for(ll l=1,r=5000;l<=n;l=r+1,r+=5000){
for(ll i=1;i<=n;i++)
bit[i].reset();
for(ll i=dl[0];i>=1;i--){
ll x=dl[i];
for(ll j=head[x];j;j=nxt[j]){
ll y=ver[j];
bit[x]|=bit[y];
}
ans[x]+=bit[x].count();
if(x>=l&&x<=r) bit[x][x-l]=1;
}
}
for(ll i=1;i<=n;i++){
sbzzn+=ans[i]-out[i];
}
printf("%d\n",sbzzn); }
int main(){
//freopen("worldline2.in","r",stdin);
//freopen("haha2.in","w",stdout);
scanf("%d%d",&n,&m);
for(ll i=1,a,b;i<=m;i++){
scanf("%d%d",&a,&b);
in[b]++;
out[a]++;
add(a,b);
}
top();
count();
}
时间机器
题解
贪心,简单线段覆盖贪心,按照左端点排序,从左端点找到右端点最靠左且能覆盖的解
验证正确性
每次枚举到左端点之前所有比当前左端点还靠左的端点都已经考虑完,若当前取不是最符合的一定不会使结果变优,若当前点放不了一定无解
代码
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define A 501010
ll T;
ll n,m;
struct node{
ll l,r,cnt,op;
friend bool operator < (const node &a,const node &b){
return (a.l==b.l)?a.op<b.op:a.l<b.l;
}
}t[A];
map<ll,ll> mp;
map<ll,ll> :: iterator it;
ll read(){
ll f=1,x=0;char c=getchar();
while(!isdigit(c)) {
if(c=='-') f=-1;
c=getchar();
}
while(isdigit(c)){
x=x*10+c-'0';
c=getchar();
}
return f*x;
}
int main(){
T=read();
while(T--){
n=read();m=read();
mp.clear();
ll cnt=0;//先节点,再电阻
for(ll i=1;i<=n;i++)
t[++cnt].l=read(),t[cnt].r=read(),t[cnt].cnt=read(),t[cnt].op=1;
for(ll i=1;i<=m;i++)
t[++cnt].l=read(),t[cnt].r=read(),t[cnt].cnt=read(),t[cnt].op=-1;
ll ok=1;//printf("oo\n");
sort(t+1,t+1+cnt);
//存节点,拿节点匹配电阻
for(ll i=1;i<=cnt;i++){
//printf("t.op=%lld\n",t[i].op);
if(t[i].op==-1)
mp[t[i].r]+=t[i].cnt;
else{
while(t[i].cnt){
it=mp.lower_bound(t[i].r);
// printf("mp[%lld]=%lld\n",t[i].r,mp[t[i].r]);
if(it==mp.end()){
ok=0;
break;
}
if(t[i].cnt>=it->second) t[i].cnt-=it->second,mp.erase(it);
else it->second-=t[i].cnt,t[i].cnt=0;
// printf("mp[%lld]=%lld\n",t[i].r,mp[t[i].r]);
}
if(!ok)break;
}
}
if(ok==0) printf("No\n");
else printf("Yes\n");
}
}
csp-s模拟测试42「世界线·时间机器·密码」的更多相关文章
- NOIP模拟测试19「count·dinner·chess」
反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...
- csp-s模拟测试44「D·E·F」
用心出题,用脚造数据 乱搞场 1 #include<bits/stdc++.h> 2 #define re register 3 #define int long long 4 #defi ...
- NOIP模拟测试30「return·one·magic」
magic 题解 首先原式指数肯定会爆$long$ $long$ 首先根据欧拉定理我们可以将原式换成$N^{\sum\limits_{i=1}^{i<=N} [gcd(i,N)==1] C_{G ...
- csp-c模拟测试43「A·B·C」
B 题解 $f[i][(gcd(prime[j]*prime[k]\%P,P))]=\sum\limits_{k=1}^{k<=num} f[i-1][k]*phi(\frac{P}{prime ...
- NOIP模拟测试38「金·斯诺·赤」
金 辗转相减见祖宗 高精 #include<bits/stdc++.h> using namespace std; #define A 2000 #define P 1 #define N ...
- NOIP模拟测试28「阴阳·虎·山洞」
写这几个题解我觉得我就像在按照官方题解抄一样 阴阳 题解 将题目中给的阴阳看作黑色和白色 首先我们观察到最后生成图中某种颜色必须是竖着单调递增或竖着单调递减 类似这样 否则不满足这个条件 但合法染色方 ...
- NOIP模拟测试20「周·任·飞」
liu_runda出的题再次$\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%$ 任 题解 题目中为什么反复强调简单路径,没有环 没有环的图中点数-边数=联通块数 前缀和维护边 ...
- NOIP模拟测试23「mine·water·gcd」
mine 题解 一道比较水的dp 考试因为初始化挂掉了只有$80$分 代码有注释 #include<bits/stdc++.h> using namespace std; //无脑dp # ...
- NOIP模拟测试16「Drink·blue·weed」
话说这次考试 Drink 非常棒的一道卡常练习题,适合练习卡常 真的很棒 前置卡常知识 1.char要比int快 char是最快的 输出putchar,输入getchar 在这个题快了7000豪 2. ...
随机推荐
- Thinking in UML 笔记(一) -- 面向对象
一.UML 中最重要的就是面向对象. 面向对象的认识论可以构建更为复杂的系统来解释复杂的世界. 1. 面向过程,一切都是相互紧密地联系在一起,互相作用,互相影响. 2.面向对象, 世界是分割开的,只有 ...
- LeetCode 26. 删除有序数组中的重复项
双指针法 分析: 设置两个指针:p1,p2,初始p1指向数组的第一个元素,p2指向第二个元素 1)如果p1的值 == p2的值,就让p2后移一位 2)如果p1的值 != p2的值,修改p1的下一个元素 ...
- Windows进程间通讯(IPC)----消息队列
消息队列 windows系统是通过消息驱动的,每移动一下鼠标,点击一下屏幕都会产生一个消息.这些消息会先被放在windows的一个系统消息队列(先进先出)中,windows系统会为每一个GUI线程创建 ...
- 33.2.NIO
4.1概述[理解] BIO Blocking IO,阻塞型IO NIO No Blocking IO,非阻塞型IO 阻塞IO的弊端 在等待的过程中,什么事也做不了 非阻塞IO的好处 不需要一直等待,当 ...
- 记一次 .NET 某外贸Web站 内存泄漏分析
一:背景 1. 讲故事 上周四有位朋友加wx咨询他的程序内存存在一定程度的泄漏,并且无法被GC回收,最终机器内存耗尽,很尴尬. 沟通下来,这位朋友能力还是很不错的,也已经做了初步的dump分析,发现了 ...
- Tomcat的使用和配置
Tomcat的使用 安装 在tomcat官网找到你需要用的 Tomcat 版本对应的 zip 压缩包,解压到需要安装的目录即可 目录介绍 bin : 专门用来存放Tomcat服务器的可执行文件 con ...
- [Qt] 基本概念
QObject :所有 Qt 类的基类 QWidget类:包含所有组件的类 Widgets:组件,组成Qt界面的基本元素 window:界面,是不含有父组件的组件 Child Widgets:子组件, ...
- Centos7如何安装开源办公软件Libreoffice
在Centos7安装了WPS,但是用了没两月就出问题,无法正常使用.(准确来说,安装的WPS一直都有各种问题存在,但是没有影响到主要功能也就将就着用,后来是直接输入不了文字) 既然是开源系统,自然而然 ...
- Linux_搭建Samba服务(认证访问)
[RHEL8]-SMBserver:[RHEL7]-SMBclient !!!测试环境我们首关闭防火墙和selinux(SMBserver和SMBclient都需要) [root@localhost ...
- Log4j 配置多个 Logger
引言 Log4j 是 Java 的主流日志框架,通过灵活的配置可以提供各种类型的日志服务. 在使用 Log4j 进行实际项目开发的过程中,有时不想使用 rootLogger 记录器,把所有的日志都输出 ...