A.梦境

如果不用去重一定要用Multiset……挂30分算是出题人手下留情了。

贪心。把点排序,区间按右端点递增排序。依次考虑每个区间,取能选的最靠左的点即可。multiset维护。

#include<cstdio>
#include<iostream>
#include<cstring>
#include<set>
#include<algorithm>
using namespace std;
int read()
{
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x*f;
}
const int N=2e5+5;
int n,m,t[N],vis[N],ans;
struct inv
{
int l,r;
friend bool operator < (const inv &x,const inv &y)
{
return x.r<y.r;
}
}a[N];
multiset<int> s;
multiset<int>::iterator it1,it2;
int main()
{
n=read();m=read();
for(int i=1;i<=n;i++)
a[i].l=read(),a[i].r=read();
for(int i=1;i<=m;i++)
t[i]=read();
sort(t+1,t+m+1);
for(int i=1;i<=m;i++)
s.insert(t[i]);
sort(a+1,a+n+1);
for(int i=1;i<=n;i++)
{
if(s.empty())break;
it1=s.lower_bound(a[i].l);
it2=s.upper_bound(a[i].r);
if(it1==s.end())continue;
if(it2!=s.begin())it2--;
else continue;
if((*it1)>(*it2))continue;
ans++;
s.erase(it1);
}
cout<<ans<<endl;
return 0;
}

B.玩具

让我懒癌发作的神dp

注意问题的转化方式以及辅助数组的正确使用姿势。

比较难的计数往往需要探究已给出条件的一些性质,并把抽象的转移过程具体化。本题的$f[i][j]=g[i-1][j-1]$就是一个很好的例子。

还有就是状态的正确设定,计数一般不会有特别鬼畜的转移方式,所以状态数组的含义十分重要。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=205;
ll n,mod;
ll dp[N][N],g[N][N],f[N][N],inv[N];
// dp:in the 1st tree
// f:tree's depth <=j
// g:forest's depth <=j
ll qpow(ll a,ll b)
{
ll res=1;a=a%mod;
while(b)
{
if(b&1)res=res*a%mod;
a=a*a%mod;
b>>=1;
}
return res;
}
int main()
{
scanf("%lld%lld",&n,&mod);
dp[1][1]=f[1][0]=1;
for(int i=1;i<=n;i++)
inv[i]=qpow(i,mod-2);
for(int i=2;i<=n;i++)
for(int j=1;j<=i;j++)
dp[i][j]=(dp[i-1][j-1]*1LL*(j-1)%mod*inv[i]%mod+dp[i-1][j]*1LL*(i-j)%mod*inv[i]%mod)%mod;
for(int i=0;i<=n;i++)
g[0][i]=1;
for(int i=1;i<=n;i++)
for(int j=0;j<=n;j++)
{
if(j)f[i][j]=g[i-1][j-1];
for(int k=1;k<=i;k++)
(g[i][j]+=f[k][j]*g[i-k][j]%mod*dp[i][k]%mod)%=mod;
}
ll ans=0;
for(int i=1;i<=n;i++)
(ans+=(f[n][i]-f[n][i-1]+mod)%mod*i%mod)%=mod;
cout<<ans<<endl;
return 0;
}

C.飘雪圣域

森林的联通块个数=点数-边数,记住了!!

上次考场能YY出来这次却想不到QAQ……

那么对于每次询问,点数已知,只需要求出这些点之间有多少边即可。

设一条边连接了$x$和$y$。那么把边排序,以$x$为下标把$y$上传到主席树上,每次查询区间有多少数 $\leq y$即可。

连图都不用建2333

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
int read()
{
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x*f;
} const int N=2e5+5;
int n,Q;
struct edge
{
int x,y;
friend bool operator < (const edge &a,const edge &b)
{
return (a.x==b.x)?(a.y<b.y):(a.x<b.x);
}
}e[N<<1];
int root[N<<5],ls[N<<5],rs[N<<5],size[N<<5],pos[N],type;
void update(int &k,int l,int r,int old,int val)
{
k=++type;
ls[k]=ls[old];rs[k]=rs[old];
size[k]=size[old]+1;
if(l==r)return ;
int mid=l+r>>1;
if(val<=mid)update(ls[k],l,mid,ls[old],val);
else update(rs[k],mid+1,r,rs[old],val);
}
int query(int k,int l,int r,int val)
{
if(l==r)return size[k];
int mid=l+r>>1;
if(val<=mid)return query(ls[k],l,mid,val);
else return size[ls[k]]+query(rs[k],mid+1,r,val);
}
int main()
{
n=read();Q=read();
for(int i=1;i<n;i++)
{
int x=read(),y=read();
e[i]=(edge){min(x,y),max(x,y)};
}
sort(e+1,e+n);
for(int i=1;i<n;i++)
{
update(root[i],1,n,root[i-1],e[i].y);
if(!pos[e[i].x])pos[e[i].x]=i;
}
pos[n]=n;root[n]=root[n-1];
for(int i=n;i;i--)
if(!pos[i])pos[i]=pos[i+1];
while(Q--)
{
int l=read(),r=read();
int lc=pos[l],rc=pos[r];
int num=query(root[rc],1,n,r)-query(root[lc-1],1,n,r);
printf("%d\n",r-l+1-num);
}
return 0;
}

[CSP-S模拟测试74]题解的更多相关文章

  1. csps模拟测试74梦境,玩具,飘雪圣域题解

    题面:https://www.cnblogs.com/Juve/articles/11679226.html 梦境: 其实还是挺水的,排序错了过不了样例,打了个二分图匹配就跑了 #include< ...

  2. [考试反思]1015csp-s模拟测试74:压迫

    其实同时也是第27,一大片并列的. 真的是越考越烂. T1是个弱化的贪心原题,15分钟拿下没什么可说的. T2打的记忆化搜索,hash_mod太小撞哈希了,50->30 T3,想不到正解,90分 ...

  3. CSP-S 模拟测试94题解

    T1 yuuustu: 可以对两边取对数,然后就转化为两个double的比较,时间复杂度$O(n)$ 然后我就用神奇0.4骗分水过 #include<bits/stdc++.h> usin ...

  4. CSP-S模拟测试 88 题解

    T1 queue: 考场写出dp柿子后觉得很斜率优化,然后因为理解错了题觉得斜率优化完全不可做,只打了暴力. 实际上他是可以乱序的,所以直接sort,正确性比较显然,贪心可证,然后就是个sb斜率优化d ...

  5. CSP-S 模拟测试92 题解

    话说我怎么觉得我没咕多长时间啊,怎么就又落了20多场题解啊 T1 array: 根据题意不难列出二元一次方程,于是可以用exgcd求解,然而还有一个限制条件就是$abs(x)+abs(y)$最小,这好 ...

  6. CSP-S 模拟测试57题解

    人生第一次A,B层一块考rank2,虽然说分差没几分,但还是值得纪念. 题解: T1 天空龙: 大神题,因为我从不写快读也没有写考场注释的习惯,所以不会做,全hzoi就kx会做,kx真大神级人物. T ...

  7. CSP-S 模拟测试 51 题解

    考试过程: 惯例先看一遍三道题,T1 一开始反应要求割点,但是这是有向图,肯定不能求割点,康了一下数据范围,有40%是树的,还不错,决定待会在打. 看T2 字符串题,完了我字符串最弱了,肯定只能打暴力 ...

  8. CSP-S 模拟测试 45 题解

    由于咕掉的题解太多了,所以只能趁改完不动题的时间,来补补坑qwq,还是太弱了. 考试过程: 到新机房的第一次考试,貌似海星? 第一题一开始就觉得是个贪心,但以为所有小怪兽都要打完,所以想复杂了,但后来 ...

  9. [CSP-S模拟测试97]题解

    A.小盆友的游戏 感觉题解解释的很牵强啊……还是打表找规律比较靠谱 对于每个人,它构造了一个期望函数$f(x)$,设它的跟班个数为$cnt[x]$,那么令$f(x)=2^{cnt[x]}-1$(??鬼 ...

随机推荐

  1. STM32 实现内部Flash的读写(HAL库版)

    Flash 中文名字叫闪存,是一种长寿命的非易失性(断电数据不丢失)的存储器.可以对称为块的存储器单元块进行擦写和再编程,在进行写入操作之前必须先执行擦除.一个Nand Flash由多个块(Block ...

  2. MySQL 对比数据库的表结构

    有时候,需要对比一下测试环境和生产环境中,数据库的表结构是否有所差异.有两个常用的工具. AmpNmp.DatabaseCompare GUI 界面,支持多种数据库(MySQL.SQL Server. ...

  3. postman测试wsdl类型接口

    1 IP地址来源搜索 WEB 服务 接口信息 http://www.webxml.com.cn/WebServices/WeatherWebService.asmx?wsdl 2  设置接口调用地址 ...

  4. 应用安全 - Web安全 - 文件包含攻防

    LFI - 无限制本地文件包含 通过目录遍历漏洞可以获取到系统中其他文件的内容 常见的敏感信息路径 Windows系统 c:\boot.ini // 查看系统版本 c:\windows\system3 ...

  5. WildFly的学习

    1. WildFly介绍: WildFly,前身是JBoss AS,从V8开始为区别于JBoss EAP,更名为WildFly. 由红帽 (Red Hat)开发,是另一个功能齐全且经过认证的应用服务器 ...

  6. 12.定义Lock类,用于锁定数据.三步走,锁的优缺点

    #在threading模块当中定义了一个Lock类,可以方便的使用锁定: # #1.创建锁 # mutex = threading.Lock() # # #2.锁定 ''' mutex.acquire ...

  7. [eclipse中使用Git插件] 008 - git操作pull、merge、stash、commit

    写在前面: 看标题其实还有001-007之类,本来准备写详细的类似教程一样的东东,但是懒了且时间有限(以后或许会补吧),所以跳到008,录下主要的操作. 所以本随笔的重点就是[pull+merge+s ...

  8. NGUI的widget的使用

    一,我们看看widget有什么属性,如下图: 二,Pivot是什么意思? 我们都知道在Untiy3D中有一个中央坐标点,而这个Pivot这个就是选择控件的某一个点与中央坐标点定位. 如下图区别: 当你 ...

  9. 攻防世界--simple-unpack

    下载链接:https://adworld.xctf.org.cn/media/task/attachments/b7cf4629544f4e759d690100c3f96caa 1.准备 获取到信息: ...

  10. vue.js(09)--v-for中的key

    v-for中key的使用注意事项 <!DOCTYPE html> <html lang="en"> <head> <meta charse ...